|
|
|
@ -17,6 +17,7 @@ from .track_details_screen import TrackDetailsScreen
|
|
|
|
|
from .track_delete_screen import TrackDeleteScreen
|
|
|
|
|
|
|
|
|
|
from ffx.track_type import TrackType
|
|
|
|
|
from ffx.model.track import Track
|
|
|
|
|
|
|
|
|
|
from ffx.track_disposition import TrackDisposition
|
|
|
|
|
from ffx.track_descriptor import TrackDescriptor
|
|
|
|
@ -33,8 +34,8 @@ class MediaDetailsScreen(Screen):
|
|
|
|
|
CSS = """
|
|
|
|
|
|
|
|
|
|
Grid {
|
|
|
|
|
grid-size: 4 8;
|
|
|
|
|
grid-rows: 8 2 2 8 2 8 2 8;
|
|
|
|
|
grid-size: 4 9;
|
|
|
|
|
grid-rows: 8 2 2 2 8 2 8 2 8;
|
|
|
|
|
grid-columns: 25 125 10 75;
|
|
|
|
|
height: 100%;
|
|
|
|
|
width: 100%;
|
|
|
|
@ -84,6 +85,10 @@ class MediaDetailsScreen(Screen):
|
|
|
|
|
row-span: 8;
|
|
|
|
|
/* tint: magenta 40%; */
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#pattern_input {
|
|
|
|
|
tint: red 40%;
|
|
|
|
|
}
|
|
|
|
|
"""
|
|
|
|
|
|
|
|
|
|
def __init__(self, patternId = None, showId = None):
|
|
|
|
@ -111,7 +116,8 @@ class MediaDetailsScreen(Screen):
|
|
|
|
|
self.__mediaDescriptor = self.__mediaFileProperties.getMediaDescriptor()
|
|
|
|
|
|
|
|
|
|
self.__mediaFilenamePattern = self.__mediaFileProperties.getPattern()
|
|
|
|
|
self.__storedMediaFilenamePattern = self.__mediaFilenamePattern.getMediaDescriptor()
|
|
|
|
|
|
|
|
|
|
self.__storedMediaFilenamePattern = self.__mediaFilenamePattern.getMediaDescriptor() if self.__mediaFilenamePattern is not None else None
|
|
|
|
|
|
|
|
|
|
# raise click.ClickException(f"diff {self.__mediaDescriptor.compare(self.__storedMediaFilenamePattern)}")
|
|
|
|
|
|
|
|
|
@ -178,6 +184,22 @@ class MediaDetailsScreen(Screen):
|
|
|
|
|
# self.subtitleStreamsTable.add_row(*map(str, row))
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def getRowIndexFromShowId(self, showId : int) -> int:
|
|
|
|
|
"""Find the index of the row where the value in the specified column matches the target_value."""
|
|
|
|
|
|
|
|
|
|
for rowKey, row in self.showsTable.rows.items(): # dict[RowKey, Row]
|
|
|
|
|
|
|
|
|
|
rowData = self.showsTable.get_row(rowKey)
|
|
|
|
|
|
|
|
|
|
try:
|
|
|
|
|
if showId == int(rowData[0]):
|
|
|
|
|
return int(self.showsTable.get_row_index(rowKey))
|
|
|
|
|
except:
|
|
|
|
|
continue
|
|
|
|
|
|
|
|
|
|
return None
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def on_mount(self):
|
|
|
|
|
|
|
|
|
|
row = (' ', '<New show>', ' ') # Convert each element to a string before adding
|
|
|
|
@ -187,15 +209,87 @@ class MediaDetailsScreen(Screen):
|
|
|
|
|
row = (int(show.id), show.name, show.year) # Convert each element to a string before adding
|
|
|
|
|
self.showsTable.add_row(*map(str, row))
|
|
|
|
|
|
|
|
|
|
# if self.show_obj:
|
|
|
|
|
# self.query_one("#showlabel", Static).update(f"{self.show_obj['id']} - {self.show_obj['name']} ({self.show_obj['year']})")
|
|
|
|
|
#
|
|
|
|
|
# if self.__pattern is not None:
|
|
|
|
|
#
|
|
|
|
|
# self.query_one("#pattern_input", Input).value = str(self.__pattern.getPattern())
|
|
|
|
|
#
|
|
|
|
|
# self.updateAudioTracks()
|
|
|
|
|
# self.updateSubtitleTracks()
|
|
|
|
|
for mediaTagKey, mediaTagValue in self.__mediaDescriptor.getTags().items():
|
|
|
|
|
row = (mediaTagKey, mediaTagValue) # Convert each element to a string before adding
|
|
|
|
|
self.mediaTagsTable.add_row(*map(str, row))
|
|
|
|
|
|
|
|
|
|
self.updateAudioTracks(self.__mediaDescriptor.getAudioTracks())
|
|
|
|
|
self.updateSubtitleTracks(self.__mediaDescriptor.getSubtitleTracks())
|
|
|
|
|
|
|
|
|
|
if self.__mediaFilenamePattern is not None:
|
|
|
|
|
|
|
|
|
|
showIdentifier = self.__mediaFilenamePattern.getShowId()
|
|
|
|
|
showRowIndex = self.getRowIndexFromShowId(showIdentifier)
|
|
|
|
|
if showRowIndex is not None:
|
|
|
|
|
self.showsTable.move_cursor(row=showRowIndex)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
self.query_one("#pattern_input", Input).value = self.__mediaFilenamePattern.getPattern()
|
|
|
|
|
|
|
|
|
|
mediaDifferences = self.__mediaDescriptor.compare(self.__mediaFilenamePattern.getMediaDescriptor())
|
|
|
|
|
|
|
|
|
|
if 'tags' in mediaDifferences.keys():
|
|
|
|
|
|
|
|
|
|
mediaTags = self.__mediaDescriptor.getTags()
|
|
|
|
|
|
|
|
|
|
if 'added' in mediaDifferences['tags'].keys():
|
|
|
|
|
|
|
|
|
|
for addedTagKey in mediaDifferences['tags']['added']:
|
|
|
|
|
|
|
|
|
|
row = (f"added media tag: key='{addedTagKey}' value='{mediaTags[addedTagKey]}'",)
|
|
|
|
|
self.differencesTable.add_row(*map(str, row))
|
|
|
|
|
|
|
|
|
|
if 'tracks' in mediaDifferences.keys():
|
|
|
|
|
|
|
|
|
|
tracks = self.__mediaDescriptor.getAllTracks()
|
|
|
|
|
|
|
|
|
|
if 'removed' in mediaDifferences['tracks'].keys():
|
|
|
|
|
|
|
|
|
|
for removedTrackIndex in mediaDifferences['tracks']['removed']:
|
|
|
|
|
|
|
|
|
|
removedTrack : Track = tracks[removedTrackIndex]
|
|
|
|
|
|
|
|
|
|
row = (f"removed {removedTrack.getType().label()} track: index={removedTrackIndex} subIndex={removedTrack.getSubIndex()} lang={removedTrack.getLanguage().threeLetter()}",)
|
|
|
|
|
self.differencesTable.add_row(*map(str, row))
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def updateAudioTracks(self, audioTracks):
|
|
|
|
|
|
|
|
|
|
self.audioStreamsTable.clear()
|
|
|
|
|
|
|
|
|
|
for at in audioTracks:
|
|
|
|
|
|
|
|
|
|
dispoSet = at.getDispositionSet()
|
|
|
|
|
|
|
|
|
|
row = (at.getSubIndex(),
|
|
|
|
|
" ",
|
|
|
|
|
at.getLanguage().label(),
|
|
|
|
|
at.getTitle(),
|
|
|
|
|
'Yes' if TrackDisposition.DEFAULT in dispoSet else 'No',
|
|
|
|
|
'Yes' if TrackDisposition.FORCED in dispoSet else 'No')
|
|
|
|
|
|
|
|
|
|
self.audioStreamsTable.add_row(*map(str, row))
|
|
|
|
|
|
|
|
|
|
def updateSubtitleTracks(self, subtitleTracks):
|
|
|
|
|
|
|
|
|
|
self.subtitleStreamsTable.clear()
|
|
|
|
|
|
|
|
|
|
for st in subtitleTracks:
|
|
|
|
|
|
|
|
|
|
dispoSet = st.getDispositionSet()
|
|
|
|
|
|
|
|
|
|
row = (st.getSubIndex(),
|
|
|
|
|
" ",
|
|
|
|
|
st.getLanguage().label(),
|
|
|
|
|
st.getTitle(),
|
|
|
|
|
'Yes' if TrackDisposition.DEFAULT in dispoSet else 'No',
|
|
|
|
|
'Yes' if TrackDisposition.FORCED in dispoSet else 'No')
|
|
|
|
|
|
|
|
|
|
self.subtitleStreamsTable.add_row(*map(str, row))
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def compose(self):
|
|
|
|
@ -205,21 +299,21 @@ class MediaDetailsScreen(Screen):
|
|
|
|
|
self.showsTable = DataTable()
|
|
|
|
|
|
|
|
|
|
# Define the columns with headers
|
|
|
|
|
self.column_key_id = self.showsTable.add_column("ID", width=10)
|
|
|
|
|
self.column_key_name = self.showsTable.add_column("Name", width=50)
|
|
|
|
|
self.column_key_year = self.showsTable.add_column("Year", width=10)
|
|
|
|
|
self.column_key_show_id = self.showsTable.add_column("ID", width=10)
|
|
|
|
|
self.column_key_show_name = self.showsTable.add_column("Name", width=50)
|
|
|
|
|
self.column_key_show_year = self.showsTable.add_column("Year", width=10)
|
|
|
|
|
|
|
|
|
|
self.showsTable.cursor_type = 'row'
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
self.trackTagsTable = DataTable()
|
|
|
|
|
self.mediaTagsTable = DataTable()
|
|
|
|
|
|
|
|
|
|
# Define the columns with headers
|
|
|
|
|
self.column_key_track_tag_key = self.trackTagsTable.add_column("Key", width=10)
|
|
|
|
|
self.column_key_track_tag_value = self.trackTagsTable.add_column("Value", width=30)
|
|
|
|
|
self.column_key_track_tag_key = self.mediaTagsTable.add_column("Key", width=20)
|
|
|
|
|
self.column_key_track_tag_value = self.mediaTagsTable.add_column("Value", width=90)
|
|
|
|
|
|
|
|
|
|
self.trackTagsTable.cursor_type = 'row'
|
|
|
|
|
self.mediaTagsTable.cursor_type = 'row'
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@ -250,12 +344,12 @@ class MediaDetailsScreen(Screen):
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# Create the DataTable widget
|
|
|
|
|
self.diffsTable = DataTable(id='differences-table') # classes="triple"
|
|
|
|
|
self.differencesTable = DataTable(id='differences-table') # classes="triple"
|
|
|
|
|
|
|
|
|
|
# Define the columns with headers
|
|
|
|
|
self.column_key_differences = self.diffsTable.add_column("Differences", width=70)
|
|
|
|
|
self.column_key_differences = self.differencesTable.add_column("Differences", width=70)
|
|
|
|
|
|
|
|
|
|
self.diffsTable.cursor_type = 'row'
|
|
|
|
|
self.differencesTable.cursor_type = 'row'
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@ -267,34 +361,39 @@ class MediaDetailsScreen(Screen):
|
|
|
|
|
yield Static("Show")
|
|
|
|
|
yield self.showsTable
|
|
|
|
|
yield Static(" ")
|
|
|
|
|
yield self.diffsTable
|
|
|
|
|
yield self.differencesTable
|
|
|
|
|
|
|
|
|
|
# 2
|
|
|
|
|
yield Static(" ")
|
|
|
|
|
yield Button("Substitute")
|
|
|
|
|
yield Static(" ")
|
|
|
|
|
|
|
|
|
|
# 3
|
|
|
|
|
yield Static("Pattern")
|
|
|
|
|
yield Input(type="text")
|
|
|
|
|
yield Input(type="text", id='pattern_input')
|
|
|
|
|
|
|
|
|
|
yield Static(" ")
|
|
|
|
|
|
|
|
|
|
# 3
|
|
|
|
|
# 4
|
|
|
|
|
yield Static(" ", classes="three")
|
|
|
|
|
|
|
|
|
|
# 4
|
|
|
|
|
# 5
|
|
|
|
|
yield Static("Media Tags")
|
|
|
|
|
yield self.trackTagsTable
|
|
|
|
|
yield self.mediaTagsTable
|
|
|
|
|
yield Static(" ")
|
|
|
|
|
|
|
|
|
|
# 5
|
|
|
|
|
# 6
|
|
|
|
|
yield Static(" ", classes="three")
|
|
|
|
|
|
|
|
|
|
# 6
|
|
|
|
|
# 7
|
|
|
|
|
yield Static("Audio Streams")
|
|
|
|
|
yield self.audioStreamsTable
|
|
|
|
|
yield Static(" ")
|
|
|
|
|
|
|
|
|
|
# 7
|
|
|
|
|
# 8
|
|
|
|
|
yield Static(" ", classes="three")
|
|
|
|
|
|
|
|
|
|
# 8
|
|
|
|
|
# 9
|
|
|
|
|
yield Static("Subtitle Streams")
|
|
|
|
|
yield self.subtitleStreamsTable
|
|
|
|
|
yield Static(" ")
|
|
|
|
|