|
1 | | -from bandcamp.app.player import Player |
2 | | - |
| 1 | +"""Provide a text-based user interface for a Bandcamp music player.""" |
3 | 2 |
|
4 | | -class TUI: |
5 | | - """Provides a text-based user interface for a Bandcamp music player.""" |
| 3 | +from bandcamp.app.player import Player |
6 | 4 |
|
7 | | - COLUMN_WIDTH = CW = 30 |
| 5 | +COLUMN_WIDTH = CW = 30 |
8 | 6 |
|
9 | | - def interact(self): |
10 | | - """Controls the player through user interactions.""" |
11 | | - with Player() as player: |
12 | | - while True: |
13 | | - print( |
14 | | - "\nType: [play <track number>], [tracks], [more], [exit]" |
15 | | - ) |
16 | | - command = input("> ").strip().lower() |
17 | 7 |
|
18 | | - if command.startswith("play"): |
| 8 | +def interact(): |
| 9 | + """Control the player through user interactions.""" |
| 10 | + with Player() as player: |
| 11 | + while True: |
| 12 | + print("\nType: play [<track_number>] | tracks | more | exit") |
| 13 | + match input("> ").strip().lower().split(): |
| 14 | + case ["play"]: |
| 15 | + play(player) |
| 16 | + case ["play", track]: |
19 | 17 | try: |
20 | | - track_number = int(command.split()[1]) |
21 | | - self.play(player, track_number) |
22 | | - except IndexError: # Play first track. |
23 | | - self.play(player) |
| 18 | + track_number = int(track) |
| 19 | + play(player, track_number) |
24 | 20 | except ValueError: |
25 | 21 | print("Please provide a valid track number.") |
26 | | - elif command == "tracks": |
27 | | - self.tracks(player) |
28 | | - elif command == "more": |
| 22 | + case ["tracks"]: |
| 23 | + display_tracks(player) |
| 24 | + case ["more"]: |
29 | 25 | player.discover.load_more() |
30 | | - self.tracks(player) |
31 | | - elif command == "exit": |
| 26 | + display_tracks(player) |
| 27 | + case ["exit"]: |
32 | 28 | print("Exiting the player...") |
33 | 29 | break |
34 | | - else: |
| 30 | + case _: |
35 | 31 | print("Unknown command. Try again.") |
36 | 32 |
|
37 | | - def play(self, player, track_number=None): |
38 | | - """Plays a track and shows info about the track.""" |
39 | | - player.play(track_number) |
40 | | - print(player._current_track._get_track_info()) |
41 | 33 |
|
42 | | - def tracks(self, player): |
43 | | - """Displays information about the currently playable tracks.""" |
44 | | - header = ( |
45 | | - f"{'#':<5} {'Album':<{self.CW}} " |
46 | | - f"{'Artist':<{self.CW}} " |
47 | | - f"{'Genre':<{self.CW}}" |
| 34 | +def play(player, track_number=None): |
| 35 | + """Play a track and show info about the track.""" |
| 36 | + player.play(track_number) |
| 37 | + print(player._current_track._get_track_info()) |
| 38 | + |
| 39 | + |
| 40 | +def display_tracks(player): |
| 41 | + """Display information about the currently playable tracks.""" |
| 42 | + header = ( |
| 43 | + f"{'#':<5} {'Album':<{CW}} " f"{'Artist':<{CW}} " f"{'Genre':<{CW}}" |
| 44 | + ) |
| 45 | + print(header) |
| 46 | + print("-" * 100) |
| 47 | + for track_number, track in enumerate( |
| 48 | + player.discover.available_tracks, start=1 |
| 49 | + ): |
| 50 | + album, artist, *genre = track.text.split("\n") |
| 51 | + album = _truncate(album, CW) |
| 52 | + artist = _truncate(artist, CW) |
| 53 | + genre = _truncate(genre[0], CW) if genre else "" |
| 54 | + print( |
| 55 | + f"{track_number:<5} {album:<{CW}} " f"{artist:<{CW}} {genre:<{CW}}" |
48 | 56 | ) |
49 | | - print(header) |
50 | | - print("-" * 100) |
51 | | - for track_number, track in enumerate( |
52 | | - player.discover.available_tracks, start=1 |
53 | | - ): |
54 | | - album, artist, *genre = track.text.split("\n") |
55 | | - album = self._truncate(album, self.CW) |
56 | | - artist = self._truncate(artist, self.CW) |
57 | | - genre = self._truncate(genre[0], self.CW) if genre else "" |
58 | | - print( |
59 | | - f"{track_number:<5} {album:<{self.CW}} " |
60 | | - f"{artist:<{self.CW}} {genre:<{self.CW}}" |
61 | | - ) |
62 | 57 |
|
63 | | - @staticmethod |
64 | | - def _truncate(text, width): |
65 | | - """Truncates track information.""" |
66 | | - return text[: width - 3] + "..." if len(text) > width else text |
| 58 | + |
| 59 | +def _truncate(text, width): |
| 60 | + """Truncate track information.""" |
| 61 | + return text[: width - 3] + "..." if len(text) > width else text |
0 commit comments