mirror of
https://github.com/jellyfin/jellyfin-web.git
synced 2024-11-18 03:18:19 -07:00
Add show/hide backdrop
This commit is contained in:
parent
05a200915e
commit
f7f83f08d4
@ -463,12 +463,18 @@ define(["loading", "appRouter", "layoutManager", "userSettings", "connectionMana
|
|||||||
var imgUrl;
|
var imgUrl;
|
||||||
var screenWidth = screen.availWidth;
|
var screenWidth = screen.availWidth;
|
||||||
var hasbackdrop = false;
|
var hasbackdrop = false;
|
||||||
|
var backdropWrapper = page.querySelector(".backdropWrapper");
|
||||||
var itemBackdropElement = page.querySelector("#itemBackdrop");
|
var itemBackdropElement = page.querySelector("#itemBackdrop");
|
||||||
|
var btnBackdropShow = page.querySelector(".btnBackdropShow");
|
||||||
var usePrimaryImage = item.MediaType === "Video" && item.Type !== "Movie" && item.Type !== "Trailer" ||
|
var usePrimaryImage = item.MediaType === "Video" && item.Type !== "Movie" && item.Type !== "Trailer" ||
|
||||||
item.MediaType && item.MediaType !== "Video" ||
|
item.MediaType && item.MediaType !== "Video" ||
|
||||||
item.Type === "MusicAlbum" ||
|
item.Type === "MusicAlbum" ||
|
||||||
item.Type === "MusicArtist";
|
item.Type === "MusicArtist";
|
||||||
|
|
||||||
|
if (layoutManager.mobile) {
|
||||||
|
backdropWrapper.classList.remove("hide");
|
||||||
|
}
|
||||||
|
|
||||||
if ("Program" === item.Type && item.ImageTags && item.ImageTags.Thumb) {
|
if ("Program" === item.Type && item.ImageTags && item.ImageTags.Thumb) {
|
||||||
imgUrl = apiClient.getScaledImageUrl(item.Id, {
|
imgUrl = apiClient.getScaledImageUrl(item.Id, {
|
||||||
type: "Thumb",
|
type: "Thumb",
|
||||||
@ -476,6 +482,7 @@ define(["loading", "appRouter", "layoutManager", "userSettings", "connectionMana
|
|||||||
tag: item.ImageTags.Thumb
|
tag: item.ImageTags.Thumb
|
||||||
});
|
});
|
||||||
itemBackdropElement.classList.remove("noBackdrop");
|
itemBackdropElement.classList.remove("noBackdrop");
|
||||||
|
btnBackdropShow.classList.remove("hide");
|
||||||
imageLoader.lazyImage(itemBackdropElement, imgUrl, false);
|
imageLoader.lazyImage(itemBackdropElement, imgUrl, false);
|
||||||
hasbackdrop = true;
|
hasbackdrop = true;
|
||||||
} else if (usePrimaryImage && item.ImageTags && item.ImageTags.Primary) {
|
} else if (usePrimaryImage && item.ImageTags && item.ImageTags.Primary) {
|
||||||
@ -485,6 +492,7 @@ define(["loading", "appRouter", "layoutManager", "userSettings", "connectionMana
|
|||||||
tag: item.ImageTags.Primary
|
tag: item.ImageTags.Primary
|
||||||
});
|
});
|
||||||
itemBackdropElement.classList.remove("noBackdrop");
|
itemBackdropElement.classList.remove("noBackdrop");
|
||||||
|
btnBackdropShow.classList.remove("hide");
|
||||||
imageLoader.lazyImage(itemBackdropElement, imgUrl, false);
|
imageLoader.lazyImage(itemBackdropElement, imgUrl, false);
|
||||||
hasbackdrop = true;
|
hasbackdrop = true;
|
||||||
} else if (item.BackdropImageTags && item.BackdropImageTags.length) {
|
} else if (item.BackdropImageTags && item.BackdropImageTags.length) {
|
||||||
@ -494,6 +502,7 @@ define(["loading", "appRouter", "layoutManager", "userSettings", "connectionMana
|
|||||||
tag: item.BackdropImageTags[0]
|
tag: item.BackdropImageTags[0]
|
||||||
});
|
});
|
||||||
itemBackdropElement.classList.remove("noBackdrop");
|
itemBackdropElement.classList.remove("noBackdrop");
|
||||||
|
btnBackdropShow.classList.remove("hide");
|
||||||
imageLoader.lazyImage(itemBackdropElement, imgUrl, false);
|
imageLoader.lazyImage(itemBackdropElement, imgUrl, false);
|
||||||
hasbackdrop = true;
|
hasbackdrop = true;
|
||||||
} else if (item.ParentBackdropItemId && item.ParentBackdropImageTags && item.ParentBackdropImageTags.length) {
|
} else if (item.ParentBackdropItemId && item.ParentBackdropImageTags && item.ParentBackdropImageTags.length) {
|
||||||
@ -503,6 +512,7 @@ define(["loading", "appRouter", "layoutManager", "userSettings", "connectionMana
|
|||||||
tag: item.ParentBackdropImageTags[0]
|
tag: item.ParentBackdropImageTags[0]
|
||||||
});
|
});
|
||||||
itemBackdropElement.classList.remove("noBackdrop");
|
itemBackdropElement.classList.remove("noBackdrop");
|
||||||
|
btnBackdropShow.classList.remove("hide");
|
||||||
imageLoader.lazyImage(itemBackdropElement, imgUrl, false);
|
imageLoader.lazyImage(itemBackdropElement, imgUrl, false);
|
||||||
hasbackdrop = true;
|
hasbackdrop = true;
|
||||||
} else if (item.ImageTags && item.ImageTags.Thumb) {
|
} else if (item.ImageTags && item.ImageTags.Thumb) {
|
||||||
@ -512,10 +522,12 @@ define(["loading", "appRouter", "layoutManager", "userSettings", "connectionMana
|
|||||||
tag: item.ImageTags.Thumb
|
tag: item.ImageTags.Thumb
|
||||||
});
|
});
|
||||||
itemBackdropElement.classList.remove("noBackdrop");
|
itemBackdropElement.classList.remove("noBackdrop");
|
||||||
|
btnBackdropShow.classList.remove("hide");
|
||||||
imageLoader.lazyImage(itemBackdropElement, imgUrl, false);
|
imageLoader.lazyImage(itemBackdropElement, imgUrl, false);
|
||||||
hasbackdrop = true;
|
hasbackdrop = true;
|
||||||
} else {
|
} else {
|
||||||
itemBackdropElement.classList.add("noBackdrop");
|
itemBackdropElement.classList.add("noBackdrop");
|
||||||
|
btnBackdropShow.classList.add("hide");
|
||||||
itemBackdropElement.style.backgroundImage = "";
|
itemBackdropElement.style.backgroundImage = "";
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1913,6 +1925,26 @@ define(["loading", "appRouter", "layoutManager", "userSettings", "connectionMana
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function showBackdrop(instance, page, apiClient, params) {
|
||||||
|
var backdropWrapper = page.querySelector(".backdropWrapper");
|
||||||
|
var btnBackdropHide = page.querySelector(".btnBackdropHide");
|
||||||
|
var btnBackdropShow = page.querySelector(".btnBackdropShow");
|
||||||
|
|
||||||
|
backdropWrapper.classList.remove("hide");
|
||||||
|
btnBackdropHide.classList.remove("hide");
|
||||||
|
btnBackdropShow.classList.add("hide");
|
||||||
|
}
|
||||||
|
|
||||||
|
function hideBackdrop(instance, page, apiClient, params) {
|
||||||
|
var backdropWrapper = page.querySelector(".backdropWrapper");
|
||||||
|
var btnBackdropHide = page.querySelector(".btnBackdropHide");
|
||||||
|
var btnBackdropShow = page.querySelector(".btnBackdropShow");
|
||||||
|
|
||||||
|
backdropWrapper.classList.add("hide");
|
||||||
|
btnBackdropHide.classList.add("hide");
|
||||||
|
btnBackdropShow.classList.remove("hide");
|
||||||
|
}
|
||||||
|
|
||||||
function getPlayOptions(startPosition) {
|
function getPlayOptions(startPosition) {
|
||||||
var audioStreamIndex = view.querySelector(".selectAudio").value || null;
|
var audioStreamIndex = view.querySelector(".selectAudio").value || null;
|
||||||
return {
|
return {
|
||||||
@ -2076,6 +2108,12 @@ define(["loading", "appRouter", "layoutManager", "userSettings", "connectionMana
|
|||||||
renderAudioSelections(view, self._currentPlaybackMediaSources);
|
renderAudioSelections(view, self._currentPlaybackMediaSources);
|
||||||
renderSubtitleSelections(view, self._currentPlaybackMediaSources);
|
renderSubtitleSelections(view, self._currentPlaybackMediaSources);
|
||||||
});
|
});
|
||||||
|
view.querySelector(".btnBackdropShow").addEventListener("click", function () {
|
||||||
|
showBackdrop(self, view, apiClient, params);
|
||||||
|
});
|
||||||
|
view.querySelector(".btnBackdropHide").addEventListener("click", function () {
|
||||||
|
hideBackdrop(self, view, apiClient, params);
|
||||||
|
});
|
||||||
view.addEventListener("click", function (e) {
|
view.addEventListener("click", function (e) {
|
||||||
if (dom.parentWithClass(e.target, "moreScenes")) {
|
if (dom.parentWithClass(e.target, "moreScenes")) {
|
||||||
apiClient.getCurrentUser().then(function (user) {
|
apiClient.getCurrentUser().then(function (user) {
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
<div id="itemDetailPage" data-role="page" class="page libraryPage itemDetailPage noSecondaryNavPage selfBackdropPage" data-backbutton="true">
|
<div id="itemDetailPage" data-role="page" class="page libraryPage itemDetailPage noSecondaryNavPage selfBackdropPage" data-backbutton="true">
|
||||||
|
|
||||||
|
<div class="backdropWrapper hide">
|
||||||
<div id="itemBackdrop" class="itemBackdrop noBackdrop">
|
<div id="itemBackdrop" class="itemBackdrop noBackdrop">
|
||||||
<button is="emby-button" type="button" class="btnPlay detailFloatingButton hide fab autoSize" title="${ButtonPlay}" data-mode="resume">
|
<button is="emby-button" type="button" class="btnPlay detailFloatingButton hide fab autoSize" title="${ButtonPlay}" data-mode="resume">
|
||||||
<i class="md-icon">play_arrow</i>
|
<i class="md-icon">play_arrow</i>
|
||||||
@ -7,7 +8,7 @@
|
|||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="detailLogo"></div>
|
<div class="detailLogo"></div>
|
||||||
|
</div>
|
||||||
<div class="detailPageWrapperContainer">
|
<div class="detailPageWrapperContainer">
|
||||||
<div class="detailPagePrimaryContainer padded-left padded-right">
|
<div class="detailPagePrimaryContainer padded-left padded-right">
|
||||||
|
|
||||||
@ -109,6 +110,20 @@
|
|||||||
<div class="detailButton-mobile-text">${ButtonMore}</div>
|
<div class="detailButton-mobile-text">${ButtonMore}</div>
|
||||||
</div>
|
</div>
|
||||||
</button>
|
</button>
|
||||||
|
|
||||||
|
<button is="emby-button" type="button" class="button-flat btnBackdropShow hide detailButton">
|
||||||
|
<div class="detailButton-mobile-content">
|
||||||
|
<i class="md-icon detailButton-mobile-icon">photo</i>
|
||||||
|
<div class="detailButton-mobile-text">${ButtonShow}</div>
|
||||||
|
</div>
|
||||||
|
</button>
|
||||||
|
|
||||||
|
<button is="emby-button" type="button" class="button-flat btnBackdropHide hide detailButton">
|
||||||
|
<div class="detailButton-mobile-content">
|
||||||
|
<i class="md-icon detailButton-mobile-icon">photo</i>
|
||||||
|
<div class="detailButton-mobile-text">${ButtonHide}</div>
|
||||||
|
</div>
|
||||||
|
</button>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="detailImageContainer verticalSection-extrabottompadding padded-left"></div>
|
<div class="detailImageContainer verticalSection-extrabottompadding padded-left"></div>
|
||||||
|
@ -84,6 +84,7 @@
|
|||||||
"ButtonGotIt": "Got It",
|
"ButtonGotIt": "Got It",
|
||||||
"ButtonGuide": "Guide",
|
"ButtonGuide": "Guide",
|
||||||
"ButtonHelp": "Help",
|
"ButtonHelp": "Help",
|
||||||
|
"ButtonHide": "Hide",
|
||||||
"ButtonHome": "Home",
|
"ButtonHome": "Home",
|
||||||
"ButtonInfo": "Info",
|
"ButtonInfo": "Info",
|
||||||
"ButtonLearnMore": "Learn more",
|
"ButtonLearnMore": "Learn more",
|
||||||
@ -120,6 +121,7 @@
|
|||||||
"ButtonSelectView": "Select view",
|
"ButtonSelectView": "Select view",
|
||||||
"ButtonSend": "Send",
|
"ButtonSend": "Send",
|
||||||
"ButtonSettings": "Settings",
|
"ButtonSettings": "Settings",
|
||||||
|
"ButtonShow": "Show",
|
||||||
"ButtonShuffle": "Shuffle",
|
"ButtonShuffle": "Shuffle",
|
||||||
"ButtonShutdown": "Shutdown",
|
"ButtonShutdown": "Shutdown",
|
||||||
"ButtonSignIn": "Sign In",
|
"ButtonSignIn": "Sign In",
|
||||||
|
Loading…
Reference in New Issue
Block a user