aboutsummaryrefslogtreecommitdiff
path: root/addons/webinterface.default
diff options
context:
space:
mode:
authorMontellese <sascha.montellese@gmail.com>2011-07-09 15:37:23 -0700
committerMontellese <sascha.montellese@gmail.com>2011-07-09 15:37:23 -0700
commit03a371e41442f37bb6db9db358237b05a27cc1fb (patch)
tree383ff235dfc765277ca750ba076df6e69c1e81d9 /addons/webinterface.default
parent20d9e7d0d7b7807a5e38f4e09b1b15cc125e665e (diff)
parentf75f6497bb28e5be0e101b37857c6d471789e888 (diff)
Merge pull request #245 from neoflex/webserver-tv-shows
webinterface: work on the TV Show section + other small fixes (thanks neoflex)
Diffstat (limited to 'addons/webinterface.default')
-rwxr-xr-x[-rw-r--r--]addons/webinterface.default/css/core.css151
-rwxr-xr-x[-rw-r--r--]addons/webinterface.default/index.html2
-rw-r--r--addons/webinterface.default/js/Core.js24
-rwxr-xr-xaddons/webinterface.default/js/MediaLibrary.js254
-rwxr-xr-x[-rw-r--r--]addons/webinterface.default/js/NowPlayingManager.js23
5 files changed, 354 insertions, 100 deletions
diff --git a/addons/webinterface.default/css/core.css b/addons/webinterface.default/css/core.css
index d22db5e381..a549bebf10 100644..100755
--- a/addons/webinterface.default/css/core.css
+++ b/addons/webinterface.default/css/core.css
@@ -80,24 +80,38 @@ body {
.albumView .floatableAlbum:hover {
background: transparent;
}
-
+
.tvshowContainer .floatableTVShowCover:hover {
background: #fff;
}
-
+
.floatableTVShowCover {
float: left;
padding: 10px;
width: 379px;
height: 70px;
}
-
+
+.floatableTVShowCoverSeason {
+ width: 500px;
+ height: 70px;
+ margin-top: 30px;
+ }
+
+.toggle .activeMode {
+ font-weight:700;
+ }
+
+#tvshowLibraryContainer {
+ padding-top:40px;
+ }
+
#libraryContainer .floatableAlbum,
#movieLibraryContainer .floatableMovieCover,
#tvshowLibraryContainer .floatableTVShowCover {
cursor: pointer;
}
-
+
.floatableAlbum div.imgWrapper,
.floatableMovieCover div.imgWrapper,
.floatableTVShowCover div.imgWrapper {
@@ -108,7 +122,14 @@ body {
text-align: center;
overflow: hidden;
}
-
+
+.floatableTVShowCoverSeason div.imgWrapper {
+ margin: auto;
+ height: 70px;
+ width: 379px;
+ display:block;
+ }
+
div.imgWrapper div.inner {
overflow: hidden;
width: 130px;
@@ -132,7 +153,10 @@ div.imgWrapper div.inner {
.floatableTVShowCover div.imgWrapper,
.floatableTVShowCover img,
-.floatableTVShowCover div.imgWrapper div.inner {
+.floatableTVShowCover div.imgWrapper div.inner,
+.floatableTVShowCoverSeason div.imgWrapper,
+.floatableTVShowCoverSeason img,
+.floatableTVShowCoverSeason div.imgWrapper div.inner {
height: 70px;
width: 379px;
}
@@ -187,7 +211,7 @@ div.imgWrapper div.inner {
top: 74px;
}
-.albumView .trackRow td {
+.albumView .trackRow td, .seasonView .episodeRow td {
cursor: pointer;
line-height: 14px;
font-size: 14px;
@@ -195,22 +219,44 @@ div.imgWrapper div.inner {
padding-left: 4px;
}
-.albumView .tr0 {
+.albumView .tr0, .seasonView .tr0 {
background-color: #efefef;
}
.albumView .tr0:hover,
-.albumView .tr1:hover {
+.albumView .tr1:hover,
+.seasonView .tr0:hover,
+.seasonView .tr1:hover {
background-color: blue;
color: #fff;
}
-
-.albumView {
+
+.seasonView .tr0:hover td.info,
+.seasonView .tr1:hover td.info{
+ background-color: cyan;
+ }
+
+.albumView, .seasonView {
width: 100%;
height: 100%;
border-collapse: collapse;
}
-
+
+.seasonView td.episodeThumb {
+ text-align:center;
+}
+.seasonView td.episodeNumber {
+ text-align:left;
+}
+.seasonView td.info {
+ background: url('%3D%3D') no-repeat;
+ background-size: 40%;
+ background-position: 50% 50%;
+}
+
+.seasonView td.episodeThumb img{
+ height:30px;
+}
.albumView td.albumThumb {
padding-left: 0px;
border-right: 1px solid #aeaeae;
@@ -227,7 +273,7 @@ div.imgWrapper div.inner {
background: url('%3D%3D') repeat-x;
}
-.albumView th {
+.albumView th, .seasonView th {
font-size: 11px;
text-align: left;
border-left: 1px solid #aeaeae;
@@ -237,10 +283,12 @@ div.imgWrapper div.inner {
padding-top: 1px;
}
-.albumView tr.headerRow {
+.albumView tr.headerRow, .seasonView tr.headerRow {
background-position: 0 -1px;
}
-
+.seasonView tr.headerRow th.thumbHeader{
+ width:40px;
+}
.albumView .albumThumb,
.albumView .albumBG {
width: 120px;
@@ -307,7 +355,7 @@ div.imgWrapper div.inner {
/* Movie Overlay */
-.moviePopoverContainer {
+.moviePopoverContainer, .episodePopoverContainer{
z-index: 3000; /* Above overlay */
border: 1px solid #000;
padding: 10px;
@@ -321,7 +369,12 @@ div.imgWrapper div.inner {
opacity: 0.9;
}
-.moviePopoverContainer .closeButton {
+.episodePopoverContainer{
+ bottom:none;
+ top:30%;
+ }
+
+.moviePopoverContainer .closeButton, .episodePopoverContainer .closeButton {
float: right;
cursor: pointer;
}
@@ -333,7 +386,14 @@ div.imgWrapper div.inner {
z-index: 3100;
}
-.moviePopoverContainer .movieTitle {
+.episodePopoverContainer .episodeCover {
+ width: 40%;
+ padding-right: 20px;
+ float: left;
+ z-index: 3100;
+ }
+
+.moviePopoverContainer .movieTitle,.episodePopoverContainer .episodeTitle {
font-size: 24px;
font-weight: 700;
color: #fff;
@@ -343,11 +403,17 @@ div.imgWrapper div.inner {
.moviePopoverContainer .runtime,
.moviePopoverContainer .director,
.moviePopoverContainer .genre,
-.moviePopoverContainer .plot {
+.moviePopoverContainer .plot,
+.episodePopoverContainer .runtime,
+.episodePopoverContainer .director,
+.episodePopoverContainer .genre,
+.episodePopoverContainer .episode,
+.episodePopoverContainer .season,
+.episodePopoverContainer .plot {
color: #fff;
}
-.movieTitle .year {
+.movieTitle .year,.episodeTitle .year {
font-weight: 400;
font-size: 18px;
}
@@ -358,8 +424,10 @@ div.imgWrapper div.inner {
z-index: 3500;
cursor: pointer;
opacity: 0.8;
+ width:100px;
}
+
.playIcon:hover {
opacity: 1;
}
@@ -391,10 +459,10 @@ div.imgWrapper div.inner {
#nowPlayingPanel {
height: 130px;
- width: 480px;
+ width: 600px;
padding: 10px;
}
-
+
#audioCoverArt img {
width: 100px;
height: 100px;
@@ -618,15 +686,20 @@ div.imgWrapper div.inner {
background: url('') no-repeat;
}
-.tvshowContainer .showDetails,
.tvshowContainer .seasonPicker {
- clear: both;
- float: left;
+ position: absolute;
+ right: 5px;
+ top: 0px;
}
+
+.tvshowContainer .active {
+ font-weight:bold;
+ }
+
.tvshowContainer .episodeListingsContainer {
position: absolute;
- top: 0px;
+ top: 40px;
left: 500px;
width: 500px;
padding-bottom: 149px;
@@ -643,27 +716,35 @@ div.imgWrapper div.inner {
}
.episodeListingsContainer li img {
- height: 200px;
+ height: 30px;
float: left;
}
-
.tvshowContainer .showDetails {
- padding: 10px;
- position: absolute;
- top: 0;
- left: 0;
+ text-align: center;
+ width: 100%;
+ height: 18px;
+ position: relative;
+ padding-top: 5px;
+ background:url('%3D%3D') repeat-x;
}
-
+
+.contentContainer .toggle{
+ position: absolute;
+ font-size: 12px;
+ font-weight: 500;
+ left: 5px;
+ top: 4px;
+}
.tvshowContainer .showDetails p {
margin: 0;
padding: 0;
}
.tvshowContainer .showDetails .showTitle {
- font-size: 20px;
+ font-size: 12px;
font-weight: 700;
}
.tvshowContainer .showDetails span.heading {
font-weight: 700;
- } \ No newline at end of file
+ }
diff --git a/addons/webinterface.default/index.html b/addons/webinterface.default/index.html
index 1603073c78..89fae65a40 100644..100755
--- a/addons/webinterface.default/index.html
+++ b/addons/webinterface.default/index.html
@@ -21,7 +21,7 @@
<ul>
<!-- <li id="remoteControl">Remote</li> -->
<li id="movieLibrary">Movies</li>
- <!-- <li id="tvshowLibrary">TV Shows</li> -->
+ <li id="tvshowLibrary">TV Shows</li>
<li id="musicLibrary">Music</li>
<!-- <li id="pictureLibrary">Pictures</li> TODO: needs pagination -->
<!-- <li id="settingsPanel">Settings</li> -->
diff --git a/addons/webinterface.default/js/Core.js b/addons/webinterface.default/js/Core.js
index 224a0b50f0..5142752e2e 100644
--- a/addons/webinterface.default/js/Core.js
+++ b/addons/webinterface.default/js/Core.js
@@ -96,4 +96,28 @@ function displayCommunicationError(m) {
function hideCommunicationError() {
$('#commsErrorPanel').hide();
+}
+function setCookie(name,value,days) {
+ if (days) {
+ var date = new Date();
+ date.setTime(date.getTime()+(days*24*60*60*1000));
+ var expires = "; expires="+date.toGMTString();
+ }
+ else var expires = "";
+ document.cookie = name+"="+value+expires+"; path=/";
+}
+
+function getCookie(name) {
+ var nameEQ = name + "=";
+ var ca = document.cookie.split(';');
+ for(var i=0;i < ca.length;i++) {
+ var c = ca[i];
+ while (c.charAt(0)==' ') c = c.substring(1,c.length);
+ if (c.indexOf(nameEQ) == 0) return c.substring(nameEQ.length,c.length);
+ }
+ return null;
+}
+
+function deleteCookie(name) {
+ setCookie(name,"",-1);
} \ No newline at end of file
diff --git a/addons/webinterface.default/js/MediaLibrary.js b/addons/webinterface.default/js/MediaLibrary.js
index 5768d3220a..7ef8a6aceb 100755
--- a/addons/webinterface.default/js/MediaLibrary.js
+++ b/addons/webinterface.default/js/MediaLibrary.js
@@ -25,9 +25,11 @@ var MediaLibrary = function() {
}
MediaLibrary.prototype = {
+
init: function() {
- this.bindControls();
+ this.bindControls();
},
+
bindControls: function() {
$('#musicLibrary').click(jQuery.proxy(this.musicLibraryOpen, this));
$('#movieLibrary').click(jQuery.proxy(this.movieLibraryOpen, this));
@@ -120,6 +122,9 @@ MediaLibrary.prototype = {
case 'tvshow':
className = 'floatableTVShowCover';
break;
+ case 'tvshowseason':
+ className = 'floatableTVShowCoverSeason';
+ break;
case 'image':
case 'directory':
className = 'floatableAlbum';
@@ -242,83 +247,178 @@ MediaLibrary.prototype = {
$('#albumDetails' + event.data.album.albumid).show();
}
},
+
+ togglePosterView: function(event){
+ var view=event.data.mode;
+ var wthumblist,hthumblist,hthumbdetails;
+ $("#toggleBanner").removeClass('activeMode');
+ $("#togglePoster").removeClass('activeMode');
+ $("#toggleLandscape").removeClass('activeMode');
+ switch(view) {
+ case 'poster':
+ setCookie('TVView','poster');
+ wthumblist='135px';
+ hthumblist='199px';
+ hthumbdetails='559px';
+ $("#togglePoster").addClass('activeMode');
+ break;
+ case 'landscape':
+ setCookie('TVView','landscape');
+ wthumblist='210px';
+ hthumblist='118px';
+ hthumbdetails='213px';
+ $("#toggleLandscape").addClass('activeMode');
+ break;
+ default: //set banner view as default
+ setCookie('TVView','banner');
+ wthumblist='379px';
+ hthumblist='70px';
+ hthumbdetails='70px';
+ $("#toggleBanner").addClass('activeMode');
+ break;
+ }
+ $(".floatableTVShowCover, .floatableTVShowCover div.imgWrapper, .floatableTVShowCover img, .floatableTVShowCover div.imgWrapper div.inner").css('width',wthumblist).css('height',hthumblist);
+ $(".floatableTVShowCoverSeason div.imgWrapper, .floatableTVShowCoverSeason div.imgWrapper div.inner,.floatableTVShowCoverSeason img, .floatableTVShowCoverSeason").css('height',hthumbdetails);
+ },
+
displayTVShowDetails: function(event) {
var tvshowDetailsContainer = $('#tvShowDetails' + event.data.tvshow.tvshowid);
$('#topScrollFade').hide();
+ toggle=this.toggle.detach();
if (!tvshowDetailsContainer || tvshowDetailsContainer.length == 0) {
$('#spinner').show();
- jQuery.post(JSON_RPC + '?GetTVShowSeasons', '{"jsonrpc": "2.0", "method": "VideoLibrary.GetSeasons", "params": { "fields": [ "season", "showtitle", "playcount", "episode", "thumbnail" ], "tvshowid" : ' + event.data.tvshow.tvshowid + ' }, "id": 1}', jQuery.proxy(function(data) {
+ jQuery.post(JSON_RPC + '?GetTVShowSeasons', '{"jsonrpc": "2.0", "method": "VideoLibrary.GetSeasons", "params": { "fields": [ "season", "showtitle", "playcount", "episode", "thumbnail","fanart" ], "tvshowid" : ' + event.data.tvshow.tvshowid + ' }, "id": 1}', jQuery.proxy(function(data) {
tvshowDetailsContainer = $('<div>');
tvshowDetailsContainer.attr('id', 'tvShowDetails' + event.data.tvshow.tvshowid)
.css('display', 'none')
.addClass('contentContainer')
.addClass('tvshowContainer');
- tvshowDetailsContainer.append(this.generateThumb('tvshow', event.data.tvshow.thumbnail, event.data.tvshow.title));
+ var showThumb = this.generateThumb('tvshowseason', event.data.tvshow.thumbnail, event.data.tvshow.title);
+
if (data && data.result && data.result.seasons && data.result.seasons.length > 0) {
- var absWrapper = $('<div>').addClass('showDetailsWrapper');
var showDetails = $('<div>').addClass('showDetails');
+ showDetails.append(toggle);
showDetails.append($('<p>').html(data.result.seasons[0].showtitle).addClass('showTitle'));
- absWrapper.append(showDetails);
- var seasonSelectionContainer = $('<div>').addClass('seasonPicker');
- var seasonSelectionList = $('<ul>');
- var episodeCount = 0;
- var firstSeason;
+ var seasonSelectionSelect = $('<select>').addClass('seasonPicker');
+ //var episodeCount = 0;
+ this.tvActiveShowContainer = tvshowDetailsContainer;
+ //var fanart;
$.each($(data.result.seasons), jQuery.proxy(function(i, item) {
- episodeCount += item.episode;
- var season = $('<li>');
- season.text(item.title);
- alert(season.text());
- if (i == 0) {
- season.addClass('activeSeason');
- firstSeason = season;
- this.tvActiveShowContainer = tvshowDetailsContainer;
- }
- season.bind('click', {tvshow: event.data.tvshow.tvshowid, season: item, element: season}, jQuery.proxy(this.displaySeasonListings, this));
- seasonSelectionList.append(season);
+// if(fanart==null && item.fanart!=null){
+// fanart=item.fanart;
+// }
+// //episodeCount += item.episode;
+ var season = $('<option>').attr('value',i);
+ season.text(item.label);
+ seasonSelectionSelect.append(season);
+
}, this));
- showDetails.append($('<p>').html('<span class="heading">Episodes:</span> ' + episodeCount));
- seasonSelectionContainer.append(seasonSelectionList);
- absWrapper.append(seasonSelectionContainer);
- tvshowDetailsContainer.append(absWrapper);
- if (firstSeason) {
- firstSeason.trigger('click');
- }
+// if(fanart!=null)
+// {
+// $('.contentContainer').css('background','url("'+this.getThumbnailPath(fanart)+'")').css('background-size','cover');
+// }
+ seasonSelectionSelect.bind('change', {tvshow: event.data.tvshow.tvshowid, seasons: data.result.seasons, element: seasonSelectionSelect}, jQuery.proxy(this.displaySeasonListings, this));
+ //showDetails.append($('<p>').html('<span class="heading">Episodes:</span> ' + episodeCount));
+ showDetails.append(seasonSelectionSelect);
+ tvshowDetailsContainer.append(showDetails);
+ tvshowDetailsContainer.append(showThumb);
+ seasonSelectionSelect.trigger('change');
$('#content').append(tvshowDetailsContainer);
+ if(getCookie('TVView')!=null && getCookie('TVView')!='banner'){
+ var view=getCookie('TVView');
+ switch(view) {
+ case 'poster':
+ togglePoster.trigger('click');
+ break;
+ case 'landscape':
+ toggleLandscape.trigger('click')
+ break;
+ }
+ }
tvshowDetailsContainer.fadeIn();
}
$('#spinner').hide();
}, this), 'json');
} else {
$('.contentContainer').hide();
- $('#tvShowDetails' + event.data.show.tvshowid);
+ $('#tvShowDetails' + event.data.tvshow.tvshowid).show();
+ $('#tvShowDetails' + event.data.tvshow.tvshowid +' select').trigger('change');
}
},
displaySeasonListings: function(event) {
- if (event.data.element != this.tvActiveSeason) {
- //Remove style from old season.
- if (this.tvActiveSeason) {
- $(this.tvActiveSeason).removeClass('activeSeason');
- }
- //Hide old listings
- var oldListings = $('.episodeListingsContainer', this.tvActiveShowContainer).fadeOut();
- //Update ActiveSeason
- this.tvActiveSeason = event.data.element;
- $(this.tvActiveSeason).addClass('activeSeason');
- //Populate new listings
- jQuery.post(JSON_RPC + '?GetTVSeasonEpisodes', '{"jsonrpc": "2.0", "method": "VideoLibrary.GetEpisodes", "params": { "fields": [ "title", "plot", "votes", "rating", "writingcredits", "firstaired", "playcount", "runtime", "director", "productioncode", "season", "episode", "showtitle", "lastplayed", "thumbnail", "file" ], "season" : ' + event.data.season.season + ', "tvshowid" : ' + event.data.tvshow + ' }, "id": 1}', jQuery.proxy(function(data) {
- var episodeListingsContainer = $('<div>').addClass('episodeListingsContainer');
- var list = $('<ul>');
- $.each($(data.result.episodes), jQuery.proxy(function(i, item) {
- var episodePicture = $('<img>');
- episodePicture.attr('src', this.getThumbnailPath(item.thumbnail));
- var episodeTitle = $('<p>').html(item.title);
- var episode = $('<li>').append(episodePicture).append(episodeTitle);
- list.append(episode);
- }, this));
- episodeListingsContainer.append(list);
- $(this.tvActiveShowContainer).prepend(episodeListingsContainer);
- }, this), 'json');
+ //retrieve selected season
+ var selectedVal=event.data.element.val();
+ var seasons=event.data.seasons;
+ $('#topScrollFade').hide();
+ //Hide old listings
+ var oldListings = $('.episodeListingsContainer', this.tvActiveShowContainer).fadeOut();
+ //Update ActiveSeason
+ this.tvActiveSeason = selectedVal;
+ //Populate new listings
+ jQuery.post(JSON_RPC + '?GetTVSeasonEpisodes', '{"jsonrpc": "2.0", "method": "VideoLibrary.GetEpisodes", "params": { "fields": [ "title", "thumbnail","episode","plot","season"], "season" : ' + seasons[selectedVal].season + ', "tvshowid" : ' + event.data.tvshow + ' }, "id": 1}', jQuery.proxy(function(data) {
+ var episodeListingsContainer = $('<div>').addClass('episodeListingsContainer');
+ var episodeTable= $('<table>').addClass('seasonView').html('<thead><tr class="headerRow"><th class="thumbHeader">N&deg;</th><th>Title</th><th class="thumbHeader">Thumb</th><th class="thumbHeader">Details</th></tr></thead><tbody class="resultSet"></tbody>');
+ $.each($(data.result.episodes), jQuery.proxy(function(i, item) {
+ var episodeRow = $('<tr>').addClass('episodeRow').addClass('tr' + i % 2);
+ var episodePictureImg = $('<img>').bind('click', { episode: item }, jQuery.proxy(this.playTVShow, this)).css('cursor','pointer');
+ episodePictureImg.attr('src', this.getThumbnailPath(item.thumbnail));
+ var episodePicture=$('<td>').addClass('episodeThumb').append(episodePictureImg).bind('click', { episode: item }, jQuery.proxy(this.playTVShow, this));
+ var episodeNumber = $('<td>').addClass('episodeNumber').html(item.episode).bind('click', { episode: item }, jQuery.proxy(this.playTVShow, this));
+ var episodeTitle = $('<td>').html(item.title).bind('click', { episode: item }, jQuery.proxy(this.playTVShow, this));
+ var episodeDetails = $('<td class="info">').html('').bind('click',{episode:item}, jQuery.proxy(this.displayEpisodeDetails, this)).css('cursor','pointer');
+ episodeRow.append(episodeNumber).append(episodeTitle).append(episodePicture).append(episodeDetails);
+ episodeTable.append(episodeRow);
+ }, this));
+ episodeListingsContainer.append(episodeTable);
+ $(this.tvActiveShowContainer).append(episodeListingsContainer);
+ }, this), 'json');
+
+ },
+
+ displayEpisodeDetails: function(event) {
+ var episodeDetails = $('<div>').attr('id', 'episode-' + event.data.episode.episodeid).addClass('episodePopoverContainer');
+ episodeDetails.append($('<img>').attr('src', '/images/close-button.png').addClass('closeButton').bind('click', jQuery.proxy(this.hideOverlay, this)));
+ episodeDetails.append($('<img>').attr('src', this.getThumbnailPath(event.data.episode.thumbnail)).addClass('episodeCover'));
+ episodeDetails.append($('<div>').addClass('playIcon').bind('click', {episode: event.data.episode}, jQuery.proxy(this.playTVShow, this)));
+ var episodeTitle = $('<p>').addClass('episodeTitle');
+ var yearText = event.data.episode.year ? ' <span class="year">(' + event.data.episode.year + ')</span>' : '';
+ episodeTitle.html(event.data.episode.title + yearText);
+ episodeDetails.append(episodeTitle);
+ if (event.data.episode.runtime) {
+ episodeDetails.append($('<p>').addClass('runtime').html('<strong>Runtime:</strong> ' + event.data.epispde.runtime + ' minutes'));
+ }
+ if (event.data.episode.season) {
+ episodeDetails.append($('<p>').addClass('season').html('<strong>Season:</strong> ' + event.data.episode.season));
+ }
+ if (event.data.episode.episode) {
+ episodeDetails.append($('<p>').addClass('episode').html('<strong>Episode:</strong> ' + event.data.episode.episode));
+ }
+ if (event.data.episode.plot) {
+ episodeDetails.append($('<p>').addClass('plot').html('<strong>Plot:</strong> <br/><br/>' +event.data.episode.plot));
}
+ if (event.data.episode.genre) {
+ episodeDetails.append($('<p>').addClass('genre').html('<strong>Genre:</strong> ' + event.data.episode.genre));
+ }
+ if (event.data.episode.rating) {
+ //Todo
+ }
+ if (event.data.episode.director) {
+ episodeDetails.append($('<p>').addClass('director').html('<strong>Directed By:</strong> ' + event.data.episode.director));
+ }
+ this.activeCover = episodeDetails;
+ $('body').append(episodeDetails);
+ $('#overlay').show();
+ this.updatePlayButtonLocation();
+ },
+
+ playTVShow: function(event) {
+ jQuery.post(JSON_RPC + '?ClearPlaylist', '{"jsonrpc": "2.0", "method": "VideoPlaylist.Clear", "id": 1}', jQuery.proxy(function(data) {
+ //check that clear worked.
+ jQuery.post(JSON_RPC + '?AddTvShowToPlaylist', '{"jsonrpc": "2.0", "method": "VideoPlaylist.Add", "params": { "item": { "episodeid": ' + event.data.episode.episodeid + ' } }, "id": 1}', jQuery.proxy(function(data) {
+ //play specific song in playlist
+ jQuery.post(JSON_RPC + '?PlaylistItemPlay', '{"jsonrpc": "2.0", "method": "VideoPlaylist.Play", "params": { "item": 0 }, "id": 1}', function(data) {this.hideOverlay();}, 'json');
+ }, this), 'json');
+ }, this), 'json');
},
hideOverlay: function(event) {
if (this.activeCover) {
@@ -332,8 +432,19 @@ MediaLibrary.prototype = {
if (movieContainer.length > 0) {
var playIcon = $('.playIcon');
if (playIcon.length > 0) {
- playIcon.width($(movieContainer[0]).width());
- playIcon.height($(movieContainer[0]).height());
+ var heightpi=$(movieContainer[0]).height();
+ playIcon.width(Math.floor(0.65*heightpi));
+ playIcon.height(heightpi);
+ }
+ }
+ var episodeContainer = $('.episodeCover');
+ if (episodeContainer.length > 0) {
+ var playIcon = $('.playIcon');
+ if (playIcon.length > 0) {
+ var widthpi=$(episodeContainer[0]).width();
+ playIcon.width(widthpi);
+ //assume 16/9 thumb
+ playIcon.height(Math.floor(widthpi*9/16));
}
}
},
@@ -423,9 +534,26 @@ MediaLibrary.prototype = {
var libraryContainer = $('#tvshowLibraryContainer');
if (!libraryContainer || libraryContainer.length == 0) {
$('#spinner').show();
+ toggle=$('<p>').addClass('toggle');
+ togglePoster= $('<span>Poster</span>');
+ togglePoster.attr('id', 'togglePoster')
+ .css('cursor','pointer')
+ .bind('click',{mode: 'poster'},jQuery.proxy(this.togglePosterView,this));
+ toggleBanner= $('<span>Banner</span>');
+ toggleBanner.attr('id', 'toggleBanner')
+ .css('cursor','pointer')
+ .addClass('activeMode')
+ .bind('click',{mode: 'banner'},jQuery.proxy(this.togglePosterView,this));
+ toggleLandscape= $('<span>Landscape</span>');
+ toggleLandscape.attr('id', 'toggleLandscape')
+ .css('cursor','pointer')
+ .bind('click',{mode: 'landscape'},jQuery.proxy(this.togglePosterView,this));
+ toggle.append(toggleBanner).append(' | ').append(togglePoster).append(' | ').append(toggleLandscape);
+ this.toggle=toggle;
jQuery.post(JSON_RPC + '?GetTVShows', '{"jsonrpc": "2.0", "method": "VideoLibrary.GetTVShows", "params": { "fields": ["genre", "plot", "title", "lastplayed", "episode", "year", "playcount", "rating", "thumbnail", "studio", "mpaa", "premiered"] }, "id": 1}', jQuery.proxy(function(data) {
if (data && data.result && data.result.tvshows) {
- libraryContainer = $('<div>');
+ libraryContainer = $('<div>');
+ libraryContainer.append(toggle);
libraryContainer.attr('id', 'tvshowLibraryContainer')
.addClass('contentContainer');
$('#content').append(libraryContainer);
@@ -442,11 +570,23 @@ MediaLibrary.prototype = {
libraryContainer.bind('scroll', { activeLibrary: libraryContainer }, jQuery.proxy(this.updateScrollEffects, this));
libraryContainer.trigger('scroll');
myScroll = new iScroll('tvshowLibraryContainer');
- }, this), 'json');
+ if(getCookie('TVView')!=null && getCookie('TVView')!='banner'){
+ var view=getCookie('TVView');
+ switch(view) {
+ case 'poster':
+ togglePoster.trigger('click');
+ break;
+ case 'landscape':
+ toggleLandscape.trigger('click')
+ break;
+ }
+ }
+ }, this), 'json');
} else {
- libraryContainer.show();
+ libraryContainer.prepend($(".toggle").detach()).show();
libraryContainer.trigger('scroll');
}
+
},
updateScrollEffects: function(event) {
if (event.data.activeLibrary && $(event.data.activeLibrary).scrollTop() > 0) {
diff --git a/addons/webinterface.default/js/NowPlayingManager.js b/addons/webinterface.default/js/NowPlayingManager.js
index cae39f5ec8..35b22b6926 100644..100755
--- a/addons/webinterface.default/js/NowPlayingManager.js
+++ b/addons/webinterface.default/js/NowPlayingManager.js
@@ -39,21 +39,26 @@ NowPlayingManager.prototype = {
type: 'POST',
url: JSON_RPC + '?UpdateState',
data: '{"jsonrpc": "2.0", "method": "Player.GetActivePlayers", "id": 1}',
- timeout: 2000,
+ timeout: 3000,
success: jQuery.proxy(function(data) {
if (data && data.result) {
if (data.result.audio && this.activePlayer != 'Audio') {
this.activePlayer = 'Audio';
this.stopVideoPlaylistUpdate();
this.displayAudioNowPlaying();
+ this.showFooter();
this.stopRefreshTime();
} else if (data.result.video && this.activePlayer != 'Video') {
this.activePlayer = 'Video';
this.stopAudioPlaylistUpdate();
this.displayVideoNowPlaying();
+ this.showFooter();
this.stopRefreshTime();
+ } else if (data.result.video || data.result.audio) {
+ this.showFooter();
} else if (!data.result.audio && !data.result.video) {
this.stopRefreshTime();
+ this.hideFooter();
}
}
setTimeout(jQuery.proxy(this.updateState, this), 1000);
@@ -81,6 +86,14 @@ NowPlayingManager.prototype = {
$('#nowPlayingPlaylist').hide();
return false;
},
+ hideFooter: function() {
+ $('#footerPopover').hide();
+ $('#overlay').css('bottom','0px');
+ },
+ showFooter: function() {
+ $('#footerPopover').show();
+ $('#overlay').css('bottom','150px');
+ },
nextTrack: function() {
if (this.activePlayer) {
jQuery.post(JSON_RPC + '?SkipNext', '{"jsonrpc": "2.0", "method": "' + this.activePlayer + 'Player.SkipNext", "id": 1}', jQuery.proxy(function(data) {
@@ -332,7 +345,7 @@ NowPlayingManager.prototype = {
refreshVideoData: function() {
if (this.autoRefreshVideoData && !this.videoRefreshTimer) {
this.videoRefreshTimer = 1;
- setTimeout(jQuery.proxy(this.refreshVideoDataLoop, this), 1000);
+ setTimeout(jQuery.proxy(this.refreshVideoDataLoop, this), 1500);
}
if (this.playing && !this.paused) {
this.trackBaseTime++;
@@ -350,10 +363,6 @@ NowPlayingManager.prototype = {
imgPath = (this.activePlaylistItem.thumbnail.startsWith('special://') ? '/vfs/' : 'images/') + this.activePlaylistItem.thumbnail;
}
$('#videoCoverArt').html('<img src="' + imgPath + '" alt="' + this.activePlaylistItem.title + ' cover art">');
- var imgWidth = $('#videoCoverArt img').width();
- $('#progressBar').width(365 - (imgWidth - 100));
- $('#videoTrackWrap').width(365 - (imgWidth - 100));
- $('#videoTitle').width(365 - (imgWidth - 100));
$('#videoShowTitle').html(this.activePlaylistItem.showtitle||'&nbsp;');
var extra = '';
if (this.activePlaylistItem.season >= 0 && this.activePlaylistItem.episode >= 0) {
@@ -412,7 +421,7 @@ NowPlayingManager.prototype = {
jQuery.ajax({
type: 'POST',
url: JSON_RPC + '?updateVideoPlaylist',
- data: '{"jsonrpc": "2.0", "method": "VideoPlaylist.GetItems", "params": { "fields": ["title", "season", "episode", "plot", "runtime", "showtitle"] }, "id": 1}',
+ data: '{"jsonrpc": "2.0", "method": "VideoPlaylist.GetItems", "params": { "fields": ["title", "season", "episode", "plot", "runtime", "showtitle","thumbnail"] }, "id": 1}',
success: jQuery.proxy(function(data) {
if (data && data.result && data.result.items && data.result.limits.total > 0) {
//Compare new playlist to active playlist, only redraw if a change is noticed.