diff options
author | Valentin Grouès <neoflexx@gmail.com> | 2011-07-03 23:59:50 +0200 |
---|---|---|
committer | Valentin Grouès <neoflexx@gmail.com> | 2011-07-10 00:25:00 +0200 |
commit | f75f6497bb28e5be0e101b37857c6d471789e888 (patch) | |
tree | 6f9a683bfdc8fe3a64293629e38f6167f7d27d0f | |
parent | 9d8f298e9b539c814de58cc684cbfc6acadafade (diff) |
work on the TV Show section of the default webserver + other small fixes and UI improvements
-rwxr-xr-x[-rw-r--r--] | addons/webinterface.default/css/core.css | 151 | ||||
-rwxr-xr-x[-rw-r--r--] | addons/webinterface.default/index.html | 2 | ||||
-rw-r--r-- | addons/webinterface.default/js/Core.js | 24 | ||||
-rwxr-xr-x[-rw-r--r--] | addons/webinterface.default/js/MediaLibrary.js | 254 | ||||
-rwxr-xr-x[-rw-r--r--] | addons/webinterface.default/js/NowPlayingManager.js | 23 |
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 348ea5f427..ec2fd5e28d 100644..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°</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||' '); 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. |