jf-roku/components/ItemGrid/MusicArtistGridItem.brs

84 lines
2.5 KiB
Plaintext
Raw Normal View History

import "pkg:/source/utils/misc.brs"
import "pkg:/source/utils/config.brs"
2022-12-10 05:06:56 +00:00
sub init()
m.itemPoster = m.top.findNode("itemPoster")
m.postTextBackground = m.top.findNode("postTextBackground")
2022-12-10 05:06:56 +00:00
m.posterText = m.top.findNode("posterText")
m.posterText.font.size = 30
m.backdrop = m.top.findNode("backdrop")
m.itemPoster.observeField("loadStatus", "onPosterLoadStatusChanged")
'Parent is MarkupGrid and it's parent is the ItemGrid
m.topParent = m.top.GetParent().GetParent()
'Get the imageDisplayMode for these grid items
if m.topParent.imageDisplayMode <> invalid
m.itemPoster.loadDisplayMode = m.topParent.imageDisplayMode
end if
m.gridTitles = m.global.session.user.settings["itemgrid.gridTitles"]
2023-01-28 20:27:32 +00:00
m.posterText.visible = false
m.postTextBackground.visible = false
2022-12-10 05:06:56 +00:00
end sub
sub itemContentChanged()
m.backdrop.blendColor = "#101010"
2023-01-28 20:27:32 +00:00
m.posterText.visible = false
m.postTextBackground.visible = false
if isValid(m.topParent.showItemTitles)
if LCase(m.topParent.showItemTitles) = "showalways"
m.posterText.visible = true
m.postTextBackground.visible = true
end if
end if
2022-12-10 05:06:56 +00:00
itemData = m.top.itemContent
if not isValid(itemData) then return
2022-12-15 01:55:03 +00:00
if LCase(itemData.type) = "musicalbum"
m.backdrop.uri = "pkg:/images/icons/album.png"
else if LCase(itemData.type) = "musicartist"
m.backdrop.uri = "pkg:/images/missingArtist.png"
else if LCase(itemData.json.type) = "musicgenre"
m.backdrop.uri = "pkg:/images/icons/musicFolder.png"
end if
2022-12-10 05:06:56 +00:00
m.itemPoster.uri = itemData.PosterUrl
m.posterText.text = itemData.title
'If Poster not loaded, ensure "blue box" is shown until loaded
if m.itemPoster.loadStatus <> "ready"
m.backdrop.visible = true
end if
2023-02-01 02:41:35 +00:00
if m.top.itemHasFocus then focusChanged()
2022-12-10 05:06:56 +00:00
end sub
'Display or hide title Visibility on focus change
sub focusChanged()
2023-01-28 22:01:08 +00:00
if m.top.itemHasFocus = true
m.posterText.repeatCount = -1
else
m.posterText.repeatCount = 0
end if
2023-01-28 20:27:32 +00:00
if isValid(m.topParent.showItemTitles)
if LCase(m.topParent.showItemTitles) = "showonhover"
m.posterText.visible = m.top.itemHasFocus
m.postTextBackground.visible = m.posterText.visible
end if
end if
end sub
2022-12-10 05:06:56 +00:00
'Hide backdrop and text when poster loaded
sub onPosterLoadStatusChanged()
if m.itemPoster.loadStatus = "ready"
m.backdrop.visible = false
end if
end sub