| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778 |
- import logging
- import mopidy.models
- from .list_view import ListView
- from .input_manager import InputManager
- from .base_screen import BaseScreen
- logger = logging.getLogger(__name__)
- class LibraryScreen(BaseScreen):
- def __init__(self, size, base_size, manager, fonts):
- BaseScreen.__init__(self, size, base_size, manager, fonts)
- self.list_view = ListView((0, 0), (
- self.size[0], self.size[1] - self.base_size),
- self.base_size,
- self.fonts['base'])
- self.directory_list = []
- self.current_directory = None
- self.library = None
- self.library_strings = None
- self.browse_uri(None)
- def get_dirty_area(self):
- return self.list_view.get_dirty_area()
- def go_inside_directory(self, uri):
- self.directory_list.append(self.current_directory)
- self.current_directory = uri
- self.browse_uri(uri)
- def browse_uri(self, uri):
- self.library_strings = []
- if uri is not None:
- self.library_strings.append("../")
- self.library = self.manager.core.library.browse(uri).get()
- for lib in self.library:
- self.library_strings.append(lib.name)
- self.list_view.set_list(self.library_strings)
- def go_up_directory(self):
- if len(self.directory_list):
- directory = self.directory_list.pop()
- self.current_directory = directory
- self.browse_uri(directory)
- def update(self, screen):
- self.list_view.render(screen)
- def touch_event(self, touch_event):
- clicked = self.list_view.touch_event(touch_event)
- if clicked is not None:
- if self.current_directory is not None:
- if clicked == 0:
- self.go_up_directory()
- else:
- if self.library[clicked - 1].type\
- == mopidy.models.Ref.TRACK:
- self.play_uri(self.current_directory, clicked-1)
- else:
- self.go_inside_directory(
- self.library[clicked - 1].uri)
- else:
- self.go_inside_directory(self.library[clicked].uri)
- def play_uri(self, uri, track_pos):
- self.manager.core.tracklist.clear()
- tracks = []
- for item in self.library:
- if item.type == mopidy.models.Ref.TRACK:
- tracks.append(self.manager.core.library.lookup(item.uri).get()[0])
- else:
- track_pos -= 1
- self.manager.core.tracklist.add(tracks)
- self.manager.core.playback.play(
- tl_track=self.manager.core.tracklist.tl_tracks.get()
- [track_pos])
|