diff --git a/data/ui/connection-panel.ui b/data/ui/connection-panel.ui
deleted file mode 100644
index d9e7364..0000000
--- a/data/ui/connection-panel.ui
+++ /dev/null
@@ -1,87 +0,0 @@
-
-
-
-
-
-
-
-
-
-
-
-
diff --git a/data/ui/server-panel.ui b/data/ui/server-panel.ui
index 3907f50..7faef17 100644
--- a/data/ui/server-panel.ui
+++ b/data/ui/server-panel.ui
@@ -2,6 +2,13 @@
+
+ 1024
+ 9999
+ 6600
+ 1
+ 100
+
horizontal
end
@@ -31,8 +38,84 @@
+ connection
+ Connection
+
+
+ network-wired-symbolic
+
+
+ false
+ center
+
+
+ true
+
+
+ No service found
+
+
+
+
+
+
+ true
+ none
+
+
+
+ Host
+ true
+
+
+
+
+
+ vertical
+
+
+
+ Port
+ start
+ false
+
+
+
+
+
+ port_spinner
+ 6600
+ server-port-adjustment
+
+
+
+
+
+
+
+ Password
+ true
+
+
+
+
+
+
+
+
+
+
+
+
status
Status
+ false
dialog-information-symbolic
@@ -149,9 +232,10 @@
-
+
stats
Statistics
+ false
starred-symbolic
@@ -298,9 +382,10 @@
-
+
devices
Audio Devices
+ false
audio-speakers-symbolic
diff --git a/data/ui/window.ui b/data/ui/window.ui
index aa73ed1..801e6a4 100644
--- a/data/ui/window.ui
+++ b/data/ui/window.ui
@@ -49,15 +49,9 @@
-
- content_stack
+
true
-
-
- true
-
-
-
+
diff --git a/data/xyz.suruatoel.mcg.gresource.xml b/data/xyz.suruatoel.mcg.gresource.xml
index 02141b3..45476d0 100644
--- a/data/xyz.suruatoel.mcg.gresource.xml
+++ b/data/xyz.suruatoel.mcg.gresource.xml
@@ -5,7 +5,6 @@
noise-texture.png
ui/window.ui
ui/shortcuts-dialog.ui
- ui/connection-panel.ui
ui/album-headerbar.ui
ui/server-panel.ui
ui/cover-panel.ui
diff --git a/po/POTFILES b/po/POTFILES
index 0263b63..7245744 100644
--- a/po/POTFILES
+++ b/po/POTFILES
@@ -1,5 +1,4 @@
data/ui/album-headerbar.ui
-data/ui/connection-panel.ui
data/ui/cover-panel.ui
data/ui/library-panel.ui
data/ui/playlist-panel.ui
@@ -9,7 +8,6 @@ data/ui/window.ui
src/albumheaderbar.py
src/application.py
src/client.py
-src/connectionpanel.py
src/coverpanel.py
src/librarypanel.py
src/main.py
diff --git a/po/de.mo b/po/de.mo
index 0977fc7..a3e8ff0 100644
Binary files a/po/de.mo and b/po/de.mo differ
diff --git a/po/de.po b/po/de.po
index 753eb6b..c169b36 100644
--- a/po/de.po
+++ b/po/de.po
@@ -2,8 +2,8 @@ msgid ""
msgstr ""
"Project-Id-Version: CoverGrid (mcg)\n"
"Report-Msgid-Bugs-To: \n"
-"POT-Creation-Date: 2024-05-22 14:39+0200\n"
-"PO-Revision-Date: 2024-05-22 14:39+0200\n"
+"POT-Creation-Date: 2024-05-24 16:44+0200\n"
+"PO-Revision-Date: 2024-05-24 16:45+0200\n"
"Last-Translator: coderkun \n"
"Language-Team: \n"
"Language: de_DE\n"
@@ -15,22 +15,6 @@ msgstr ""
"X-Poedit-Basepath: ../../..\n"
"X-Poedit-SourceCharset: UTF-8\n"
-#: data/ui/connection-panel.ui:29
-msgid "No service found"
-msgstr "Keine Dienste gefunden"
-
-#: data/ui/connection-panel.ui:43
-msgid "Host"
-msgstr "Host"
-
-#: data/ui/connection-panel.ui:56
-msgid "Port"
-msgstr "Port"
-
-#: data/ui/connection-panel.ui:76
-msgid "Password"
-msgstr "Passwort"
-
#: data/ui/cover-panel.ui:12 data/ui/shortcuts-dialog.ui:88
msgid "Show the cover in fullscreen mode"
msgstr "Das Cover im Vollbildmodus anzeigen"
@@ -79,15 +63,15 @@ msgstr "Einstellungen und Aktionen"
msgid "search library"
msgstr "Bibliothek durchsuchen"
-#: data/ui/library-panel.ui:263 data/ui/playlist-panel.ui:107
+#: data/ui/library-panel.ui:264 data/ui/playlist-panel.ui:107
msgid "cancel"
msgstr "abbrechen"
-#: data/ui/library-panel.ui:270 data/ui/library-panel.ui:327
+#: data/ui/library-panel.ui:271 data/ui/library-panel.ui:328
msgid "queue"
msgstr "einreihen"
-#: data/ui/library-panel.ui:320 data/ui/playlist-panel.ui:163
+#: data/ui/library-panel.ui:321 data/ui/playlist-panel.ui:163
msgid "play"
msgstr "abspielen"
@@ -99,60 +83,80 @@ msgstr "Die Wiedergabeliste leeren"
msgid "remove"
msgstr "entfernen"
-#: data/ui/server-panel.ui:35
+#: data/ui/server-panel.ui:42
+msgid "Connection"
+msgstr "Verbindung"
+
+#: data/ui/server-panel.ui:55
+msgid "No service found"
+msgstr "Keine Dienste gefunden"
+
+#: data/ui/server-panel.ui:69
+msgid "Host"
+msgstr "Host"
+
+#: data/ui/server-panel.ui:82
+msgid "Port"
+msgstr "Port"
+
+#: data/ui/server-panel.ui:102
+msgid "Password"
+msgstr "Passwort"
+
+#: data/ui/server-panel.ui:117
msgid "Status"
msgstr "Status"
-#: data/ui/server-panel.ui:49
+#: data/ui/server-panel.ui:132
msgid "File:"
msgstr "Datei:"
-#: data/ui/server-panel.ui:60
+#: data/ui/server-panel.ui:143
msgid "Audio:"
msgstr "Audio:"
-#: data/ui/server-panel.ui:71
+#: data/ui/server-panel.ui:154
msgid "Bitrate:"
msgstr "Bitrate:"
-#: data/ui/server-panel.ui:82
+#: data/ui/server-panel.ui:165
msgid "Error:"
msgstr "Fehler:"
-#: data/ui/server-panel.ui:92 data/ui/server-panel.ui:106
-#: data/ui/server-panel.ui:120 data/ui/server-panel.ui:134
+#: data/ui/server-panel.ui:175 data/ui/server-panel.ui:189
+#: data/ui/server-panel.ui:203 data/ui/server-panel.ui:217
msgid "none"
msgstr "nichts"
-#: data/ui/server-panel.ui:154
+#: data/ui/server-panel.ui:237
msgid "Statistics"
msgstr "Statistiken"
-#: data/ui/server-panel.ui:178
+#: data/ui/server-panel.ui:262
msgid "Artists"
msgstr "Künstler"
-#: data/ui/server-panel.ui:198
+#: data/ui/server-panel.ui:282
msgid "Albums"
msgstr "Alben"
-#: data/ui/server-panel.ui:218
+#: data/ui/server-panel.ui:302
msgid "Songs"
msgstr "Songs"
-#: data/ui/server-panel.ui:238
+#: data/ui/server-panel.ui:322
msgid "Seconds"
msgstr "Sekunden"
-#: data/ui/server-panel.ui:267
+#: data/ui/server-panel.ui:351
msgid "Seconds played"
msgstr "Sekunden gespielt"
-#: data/ui/server-panel.ui:287
+#: data/ui/server-panel.ui:371
msgid "Seconds running"
msgstr "Sekunden laufend"
-#: data/ui/server-panel.ui:303
+#: data/ui/server-panel.ui:387
msgid "Audio Devices"
msgstr "Audiogeräte"
@@ -208,18 +212,18 @@ msgstr "Cover-Paneel"
msgid "Library Panel"
msgstr "Bibliothekspaneel"
-#: src/connectionpanel.py:51
-msgid "use"
-msgstr "verwenden"
-
#: src/librarypanel.py:291
msgid "Loading albums"
msgstr "Alben werden geladen"
-#: src/librarypanel.py:379
+#: src/librarypanel.py:370
msgid "Loading images"
msgstr "Bilder werden geladen"
+#: src/serverpanel.py:77
+msgid "use"
+msgstr "verwenden"
+
#: src/utils.py:50 src/utils.py:67
msgid "{} feat. {}"
msgstr "{} mit {}"
@@ -228,19 +232,20 @@ msgstr "{} mit {}"
msgid "{}:{} minutes"
msgstr "{}:{} Minuten"
-#: src/window.py:114
+#. Stack
+#: src/window.py:106
msgid "Server"
msgstr "Server"
-#: src/window.py:115
+#: src/window.py:107
msgid "Cover"
msgstr "Cover"
-#: src/window.py:116
+#: src/window.py:108
msgid "Playlist"
msgstr "Wiedergabeliste"
-#: src/window.py:117
+#: src/window.py:109
msgid "Library"
msgstr "Bibliothek"
@@ -275,9 +280,6 @@ msgstr "Bibliothek"
#~ msgid "Search Library"
#~ msgstr "Bibliothek durchsuchen"
-#~ msgid "Connection"
-#~ msgstr "Verbindung"
-
#~ msgid "Keyboard Shortcuts"
#~ msgstr "Tastenkombinationen"
diff --git a/po/en.mo b/po/en.mo
index 96e0ea4..3edbb64 100644
Binary files a/po/en.mo and b/po/en.mo differ
diff --git a/po/en.po b/po/en.po
index 00593af..e30d4d4 100644
--- a/po/en.po
+++ b/po/en.po
@@ -2,8 +2,8 @@ msgid ""
msgstr ""
"Project-Id-Version: CoverGrid (mcg)\n"
"Report-Msgid-Bugs-To: \n"
-"POT-Creation-Date: 2024-05-22 14:39+0200\n"
-"PO-Revision-Date: 2024-05-22 14:39+0200\n"
+"POT-Creation-Date: 2024-05-24 16:44+0200\n"
+"PO-Revision-Date: 2024-05-24 16:45+0200\n"
"Last-Translator: coderkun \n"
"Language-Team: \n"
"Language: en\n"
@@ -16,22 +16,6 @@ msgstr ""
"X-Poedit-SearchPath-0: mcg\n"
"X-Poedit-SearchPath-1: data/ui\n"
-#: data/ui/connection-panel.ui:29
-msgid "No service found"
-msgstr "No service found"
-
-#: data/ui/connection-panel.ui:43
-msgid "Host"
-msgstr "Host"
-
-#: data/ui/connection-panel.ui:56
-msgid "Port"
-msgstr "Port"
-
-#: data/ui/connection-panel.ui:76
-msgid "Password"
-msgstr "Password"
-
#: data/ui/cover-panel.ui:12 data/ui/shortcuts-dialog.ui:88
msgid "Show the cover in fullscreen mode"
msgstr "Show the cover in fullscreen mode"
@@ -80,15 +64,15 @@ msgstr "Settings and actions"
msgid "search library"
msgstr "search library"
-#: data/ui/library-panel.ui:263 data/ui/playlist-panel.ui:107
+#: data/ui/library-panel.ui:264 data/ui/playlist-panel.ui:107
msgid "cancel"
msgstr "cancel"
-#: data/ui/library-panel.ui:270 data/ui/library-panel.ui:327
+#: data/ui/library-panel.ui:271 data/ui/library-panel.ui:328
msgid "queue"
msgstr "queue"
-#: data/ui/library-panel.ui:320 data/ui/playlist-panel.ui:163
+#: data/ui/library-panel.ui:321 data/ui/playlist-panel.ui:163
msgid "play"
msgstr "play"
@@ -100,60 +84,80 @@ msgstr "Clear the playlist"
msgid "remove"
msgstr "remove"
-#: data/ui/server-panel.ui:35
+#: data/ui/server-panel.ui:42
+msgid "Connection"
+msgstr "Connection"
+
+#: data/ui/server-panel.ui:55
+msgid "No service found"
+msgstr "No service found"
+
+#: data/ui/server-panel.ui:69
+msgid "Host"
+msgstr "Host"
+
+#: data/ui/server-panel.ui:82
+msgid "Port"
+msgstr "Port"
+
+#: data/ui/server-panel.ui:102
+msgid "Password"
+msgstr "Password"
+
+#: data/ui/server-panel.ui:117
msgid "Status"
msgstr "Status"
-#: data/ui/server-panel.ui:49
+#: data/ui/server-panel.ui:132
msgid "File:"
msgstr "File:"
-#: data/ui/server-panel.ui:60
+#: data/ui/server-panel.ui:143
msgid "Audio:"
msgstr "Audio:"
-#: data/ui/server-panel.ui:71
+#: data/ui/server-panel.ui:154
msgid "Bitrate:"
msgstr "Bitrate:"
-#: data/ui/server-panel.ui:82
+#: data/ui/server-panel.ui:165
msgid "Error:"
msgstr "Error:"
-#: data/ui/server-panel.ui:92 data/ui/server-panel.ui:106
-#: data/ui/server-panel.ui:120 data/ui/server-panel.ui:134
+#: data/ui/server-panel.ui:175 data/ui/server-panel.ui:189
+#: data/ui/server-panel.ui:203 data/ui/server-panel.ui:217
msgid "none"
msgstr "none"
-#: data/ui/server-panel.ui:154
+#: data/ui/server-panel.ui:237
msgid "Statistics"
msgstr "Statistics"
-#: data/ui/server-panel.ui:178
+#: data/ui/server-panel.ui:262
msgid "Artists"
msgstr "Artists"
-#: data/ui/server-panel.ui:198
+#: data/ui/server-panel.ui:282
msgid "Albums"
msgstr "Albums"
-#: data/ui/server-panel.ui:218
+#: data/ui/server-panel.ui:302
msgid "Songs"
msgstr "Songs"
-#: data/ui/server-panel.ui:238
+#: data/ui/server-panel.ui:322
msgid "Seconds"
msgstr "Seconds"
-#: data/ui/server-panel.ui:267
+#: data/ui/server-panel.ui:351
msgid "Seconds played"
msgstr "Seconds"
-#: data/ui/server-panel.ui:287
+#: data/ui/server-panel.ui:371
msgid "Seconds running"
msgstr "Seconds running"
-#: data/ui/server-panel.ui:303
+#: data/ui/server-panel.ui:387
msgid "Audio Devices"
msgstr "Audio Devices"
@@ -209,18 +213,18 @@ msgstr "Cover Panel"
msgid "Library Panel"
msgstr "Library Panel"
-#: src/connectionpanel.py:51
-msgid "use"
-msgstr "use"
-
#: src/librarypanel.py:291
msgid "Loading albums"
msgstr "Loading albums"
-#: src/librarypanel.py:379
+#: src/librarypanel.py:370
msgid "Loading images"
msgstr "Loading images"
+#: src/serverpanel.py:77
+msgid "use"
+msgstr "use"
+
#: src/utils.py:50 src/utils.py:67
msgid "{} feat. {}"
msgstr "{} feat. {}"
@@ -229,19 +233,20 @@ msgstr "{} feat. {}"
msgid "{}:{} minutes"
msgstr "{}:{} minutes"
-#: src/window.py:114
+#. Stack
+#: src/window.py:106
msgid "Server"
msgstr "Server"
-#: src/window.py:115
+#: src/window.py:107
msgid "Cover"
msgstr "Cover"
-#: src/window.py:116
+#: src/window.py:108
msgid "Playlist"
msgstr "Playlist"
-#: src/window.py:117
+#: src/window.py:109
msgid "Library"
msgstr "Library"
@@ -276,9 +281,6 @@ msgstr "Library"
#~ msgid "Search Library"
#~ msgstr "Search Library"
-#~ msgid "Connection"
-#~ msgstr "Connection"
-
#~ msgid "Keyboard Shortcuts"
#~ msgstr "Keyboard Shortcuts"
diff --git a/po/mcg.pot b/po/mcg.pot
index 451e0a8..e2cffcb 100644
--- a/po/mcg.pot
+++ b/po/mcg.pot
@@ -8,7 +8,7 @@ msgid ""
msgstr ""
"Project-Id-Version: mcg\n"
"Report-Msgid-Bugs-To: \n"
-"POT-Creation-Date: 2024-05-22 14:39+0200\n"
+"POT-Creation-Date: 2024-05-24 16:44+0200\n"
"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
"Last-Translator: FULL NAME \n"
"Language-Team: LANGUAGE \n"
@@ -17,22 +17,6 @@ msgstr ""
"Content-Type: text/plain; charset=CHARSET\n"
"Content-Transfer-Encoding: 8bit\n"
-#: data/ui/connection-panel.ui:29
-msgid "No service found"
-msgstr ""
-
-#: data/ui/connection-panel.ui:43
-msgid "Host"
-msgstr ""
-
-#: data/ui/connection-panel.ui:56
-msgid "Port"
-msgstr ""
-
-#: data/ui/connection-panel.ui:76
-msgid "Password"
-msgstr ""
-
#: data/ui/cover-panel.ui:12 data/ui/shortcuts-dialog.ui:88
msgid "Show the cover in fullscreen mode"
msgstr ""
@@ -81,15 +65,15 @@ msgstr ""
msgid "search library"
msgstr ""
-#: data/ui/library-panel.ui:263 data/ui/playlist-panel.ui:107
+#: data/ui/library-panel.ui:264 data/ui/playlist-panel.ui:107
msgid "cancel"
msgstr ""
-#: data/ui/library-panel.ui:270 data/ui/library-panel.ui:327
+#: data/ui/library-panel.ui:271 data/ui/library-panel.ui:328
msgid "queue"
msgstr ""
-#: data/ui/library-panel.ui:320 data/ui/playlist-panel.ui:163
+#: data/ui/library-panel.ui:321 data/ui/playlist-panel.ui:163
msgid "play"
msgstr ""
@@ -101,60 +85,80 @@ msgstr ""
msgid "remove"
msgstr ""
-#: data/ui/server-panel.ui:35
-msgid "Status"
+#: data/ui/server-panel.ui:42
+msgid "Connection"
msgstr ""
-#: data/ui/server-panel.ui:49
-msgid "File:"
+#: data/ui/server-panel.ui:55
+msgid "No service found"
msgstr ""
-#: data/ui/server-panel.ui:60
-msgid "Audio:"
-msgstr ""
-
-#: data/ui/server-panel.ui:71
-msgid "Bitrate:"
+#: data/ui/server-panel.ui:69
+msgid "Host"
msgstr ""
#: data/ui/server-panel.ui:82
-msgid "Error:"
+msgid "Port"
msgstr ""
-#: data/ui/server-panel.ui:92 data/ui/server-panel.ui:106
-#: data/ui/server-panel.ui:120 data/ui/server-panel.ui:134
-msgid "none"
+#: data/ui/server-panel.ui:102
+msgid "Password"
+msgstr ""
+
+#: data/ui/server-panel.ui:117
+msgid "Status"
+msgstr ""
+
+#: data/ui/server-panel.ui:132
+msgid "File:"
+msgstr ""
+
+#: data/ui/server-panel.ui:143
+msgid "Audio:"
msgstr ""
#: data/ui/server-panel.ui:154
+msgid "Bitrate:"
+msgstr ""
+
+#: data/ui/server-panel.ui:165
+msgid "Error:"
+msgstr ""
+
+#: data/ui/server-panel.ui:175 data/ui/server-panel.ui:189
+#: data/ui/server-panel.ui:203 data/ui/server-panel.ui:217
+msgid "none"
+msgstr ""
+
+#: data/ui/server-panel.ui:237
msgid "Statistics"
msgstr ""
-#: data/ui/server-panel.ui:178
+#: data/ui/server-panel.ui:262
msgid "Artists"
msgstr ""
-#: data/ui/server-panel.ui:198
+#: data/ui/server-panel.ui:282
msgid "Albums"
msgstr ""
-#: data/ui/server-panel.ui:218
+#: data/ui/server-panel.ui:302
msgid "Songs"
msgstr ""
-#: data/ui/server-panel.ui:238
+#: data/ui/server-panel.ui:322
msgid "Seconds"
msgstr ""
-#: data/ui/server-panel.ui:267
+#: data/ui/server-panel.ui:351
msgid "Seconds played"
msgstr ""
-#: data/ui/server-panel.ui:287
+#: data/ui/server-panel.ui:371
msgid "Seconds running"
msgstr ""
-#: data/ui/server-panel.ui:303
+#: data/ui/server-panel.ui:387
msgid "Audio Devices"
msgstr ""
@@ -210,18 +214,18 @@ msgstr ""
msgid "Library Panel"
msgstr ""
-#: src/connectionpanel.py:51
-msgid "use"
-msgstr ""
-
#: src/librarypanel.py:291
msgid "Loading albums"
msgstr ""
-#: src/librarypanel.py:379
+#: src/librarypanel.py:370
msgid "Loading images"
msgstr ""
+#: src/serverpanel.py:77
+msgid "use"
+msgstr ""
+
#: src/utils.py:50 src/utils.py:67
msgid "{} feat. {}"
msgstr ""
@@ -230,18 +234,19 @@ msgstr ""
msgid "{}:{} minutes"
msgstr ""
-#: src/window.py:114
+#. Stack
+#: src/window.py:106
msgid "Server"
msgstr ""
-#: src/window.py:115
+#: src/window.py:107
msgid "Cover"
msgstr ""
-#: src/window.py:116
+#: src/window.py:108
msgid "Playlist"
msgstr ""
-#: src/window.py:117
+#: src/window.py:109
msgid "Library"
msgstr ""
diff --git a/src/connectionpanel.py b/src/connectionpanel.py
deleted file mode 100644
index a4060ed..0000000
--- a/src/connectionpanel.py
+++ /dev/null
@@ -1,89 +0,0 @@
-#!/usr/bin/env python3
-
-import gi
-import locale
-
-gi.require_version('Gtk', '4.0')
-gi.require_version('Adw', '1')
-from gi.repository import Gtk, GObject, Adw
-from mcg.zeroconf import ZeroconfProvider
-
-
-@Gtk.Template(resource_path='/xyz/suruatoel/mcg/ui/connection-panel.ui')
-class ConnectionPanel(Adw.Bin):
- __gtype_name__ = 'McgConnectionPanel'
- __gsignals__ = {
- 'connection-changed': (GObject.SIGNAL_RUN_FIRST, None, (str, int, str))
- }
-
- # Widgets
- toolbar = Gtk.Template.Child()
- zeroconf_list = Gtk.Template.Child()
- host_row = Gtk.Template.Child()
- port_spinner = Gtk.Template.Child()
- password_row = Gtk.Template.Child()
-
- def __init__(self, **kwargs):
- super().__init__(**kwargs)
-
- # Zeroconf provider
- self._zeroconf_provider = ZeroconfProvider()
- self._zeroconf_provider.connect_signal(
- ZeroconfProvider.SIGNAL_SERVICE_NEW, self.on_new_service)
-
- def on_new_service(self, service):
- name, host, port = service
-
- row_button = Gtk.Button()
- row_button.set_label(locale.gettext("use"))
- row_button.connect("clicked", self.on_service_selected, host, port)
-
- row = Adw.ActionRow()
- row.set_title(name)
- row.set_subtitle("{} ({})".format(host, port))
- row.add_suffix(row_button)
-
- self.zeroconf_list.insert(row, -1)
-
- def on_service_selected(self, widget, host, port):
- self.set_host(host)
- self.set_port(port)
-
- @Gtk.Template.Callback()
- def on_host_entry_apply(self, widget):
- self._call_back()
-
- @Gtk.Template.Callback()
- def on_port_spinner_value_changed(self, widget):
- self._call_back()
-
- def set_host(self, host):
- self.host_row.set_text(host)
-
- def get_host(self):
- return self.host_row.get_text()
-
- def set_port(self, port):
- self.port_spinner.set_value(port)
-
- def get_port(self):
- return self.port_spinner.get_value_as_int()
-
- def set_password(self, password):
- if password is None:
- password = ""
- self.password_row.set_text(password)
-
- def get_password(self):
- if self.password_row.get_text() == "":
- return None
- else:
- return self.password_entry.get_text()
-
- def _call_back(self):
- self.emit(
- 'connection-changed',
- self.get_host(),
- self.get_port(),
- self.get_password(),
- )
diff --git a/src/meson.build b/src/meson.build
index d30b1c7..e2db64e 100644
--- a/src/meson.build
+++ b/src/meson.build
@@ -23,7 +23,6 @@ mcg_sources = [
'albumheaderbar.py',
'application.py',
'client.py',
- 'connectionpanel.py',
'coverpanel.py',
'librarypanel.py',
'playlistpanel.py',
diff --git a/src/serverpanel.py b/src/serverpanel.py
index f29c7c4..cc765bc 100644
--- a/src/serverpanel.py
+++ b/src/serverpanel.py
@@ -4,13 +4,19 @@ import gi
gi.require_version('Gtk', '4.0')
gi.require_version('Adw', '1')
+import locale
+
from gi.repository import Gtk, Adw, GObject
+from mcg.zeroconf import ZeroconfProvider
+
@Gtk.Template(resource_path='/xyz/suruatoel/mcg/ui/server-panel.ui')
class ServerPanel(Adw.Bin):
__gtype_name__ = 'McgServerPanel'
__gsignals__ = {
+ 'connection-changed':
+ (GObject.SIGNAL_RUN_FIRST, None, (str, int, str)),
'change-output-device': (GObject.SIGNAL_RUN_FIRST, None, (
GObject.TYPE_PYOBJECT,
bool,
@@ -19,6 +25,15 @@ class ServerPanel(Adw.Bin):
# Widgets
toolbar = Gtk.Template.Child()
+ connection_status_page = Gtk.Template.Child()
+ status_page = Gtk.Template.Child()
+ stats_page = Gtk.Template.Child()
+ devices_page = Gtk.Template.Child()
+ # Connection widgets
+ zeroconf_list = Gtk.Template.Child()
+ host_row = Gtk.Template.Child()
+ port_spinner = Gtk.Template.Child()
+ password_row = Gtk.Template.Child()
# Status widgets
status_file = Gtk.Template.Child()
status_audio = Gtk.Template.Child()
@@ -43,12 +58,72 @@ class ServerPanel(Adw.Bin):
# Widgets
self._none_label = self.status_file.get_label()
+ # Zeroconf provider
+ self._zeroconf_provider = ZeroconfProvider()
+ self._zeroconf_provider.connect_signal(
+ ZeroconfProvider.SIGNAL_SERVICE_NEW, self.on_new_service)
+
def set_selected(self, selected):
self._is_selected = selected
def get_toolbar(self):
return self.toolbar
+ def on_new_service(self, service):
+ name, host, port = service
+
+ row_button = Gtk.Button()
+ row_button.set_label(locale.gettext("use"))
+ row_button.connect("clicked", self.on_service_selected, host, port)
+
+ row = Adw.ActionRow()
+ row.set_title(name)
+ row.set_subtitle("{} ({})".format(host, port))
+ row.add_suffix(row_button)
+
+ self.zeroconf_list.insert(row, -1)
+
+ def on_service_selected(self, widget, host, port):
+ self.set_host(host)
+ self.set_port(port)
+
+ @Gtk.Template.Callback()
+ def on_host_entry_apply(self, widget):
+ self._call_back()
+
+ @Gtk.Template.Callback()
+ def on_port_spinner_value_changed(self, widget):
+ self._call_back()
+
+ def set_connection_sensitive(self, sensitive):
+ self.connection_status_page.set_sensitive(sensitive)
+ self.status_page.set_visible(not sensitive)
+ self.stats_page.set_visible(not sensitive)
+ self.devices_page.set_visible(not sensitive)
+
+ def set_host(self, host):
+ self.host_row.set_text(host)
+
+ def get_host(self):
+ return self.host_row.get_text()
+
+ def set_port(self, port):
+ self.port_spinner.set_value(port)
+
+ def get_port(self):
+ return self.port_spinner.get_value_as_int()
+
+ def set_password(self, password):
+ if password is None:
+ password = ""
+ self.password_row.set_text(password)
+
+ def get_password(self):
+ if self.password_row.get_text() == "":
+ return None
+ else:
+ return self.password_entry.get_text()
+
def on_output_device_toggled(self, widget, device):
self.emit('change-output-device', device, widget.get_active())
@@ -113,3 +188,12 @@ class ServerPanel(Adw.Bin):
if id not in device_ids:
self.output_devices.remove(
self._output_buttons[id].get_parent())
+
+ def _call_back(self):
+ self.emit(
+ 'connection-changed',
+ self.get_host(),
+ self.get_port(),
+ self.get_password(),
+ )
+
diff --git a/src/window.py b/src/window.py
index db10c23..ed00409 100644
--- a/src/window.py
+++ b/src/window.py
@@ -14,7 +14,6 @@ gi.require_version('Adw', '1')
from gi.repository import Gtk, Adw, Gdk, GObject, GLib, Gio
from . import client
from .shortcutsdialog import ShortcutsDialog
-from .connectionpanel import ConnectionPanel
from .serverpanel import ServerPanel
from .coverpanel import CoverPanel
from .playlistpanel import PlaylistPanel
@@ -52,7 +51,6 @@ class Window(Adw.ApplicationWindow):
# Widgets
toolbar_view = Gtk.Template.Child()
- content_stack = Gtk.Template.Child()
panel_stack = Gtk.Template.Child()
toolbar_stack = Gtk.Template.Child()
# Headerbar
@@ -81,8 +79,6 @@ class Window(Adw.ApplicationWindow):
# Help/Shortcuts dialog
self.set_help_overlay(ShortcutsDialog())
- # Login screen
- self._connection_panel = ConnectionPanel()
# Server panel
self._server_panel = ServerPanel()
self._panels.append(self._server_panel)
@@ -104,7 +100,6 @@ class Window(Adw.ApplicationWindow):
self.on_panel_close_standalone)
self._panels.append(self._library_panel)
# Stack
- self.content_stack.add_child(self._connection_panel)
self.panel_stack.add_titled_with_icon(self._server_panel,
'server-panel',
locale.gettext("Server"),
@@ -128,12 +123,12 @@ class Window(Adw.ApplicationWindow):
# Properties
self._set_headerbar_sensitive(False, False)
- self._connection_panel.set_host(
+ self._server_panel.set_host(
self._settings.get_string(Window.SETTING_HOST))
- self._connection_panel.set_port(
- self._settings.get_int(Window.SETTING_PORT))
+ self._server_panel.set_port(self._settings.get_int(
+ Window.SETTING_PORT))
if use_keyring:
- self._connection_panel.set_password(
+ self._server_panel.set_password(
keyring.get_password(ZeroconfProvider.KEYRING_SYSTEM,
ZeroconfProvider.KEYRING_USERNAME))
self._playlist_panel.set_item_size(
@@ -148,8 +143,9 @@ class Window(Adw.ApplicationWindow):
# Signals
self.connect("notify::maximized", self.on_maximized)
self.connect("notify::fullscreened", self.on_fullscreened)
- self._connection_panel.connect(
- 'connection-changed', self.on_connection_panel_connection_changed)
+ self._server_panel.connect('connection-changed',
+ self.on_server_panel_connection_changed)
+
self.panel_stack.connect('notify::visible-child',
self.on_stack_switched)
self._server_panel.connect('change-output-device',
@@ -219,7 +215,7 @@ class Window(Adw.ApplicationWindow):
self.set_default_size(self._state.width, self._state.height)
if self._state.get_property(WindowState.PROP_MAXIMIZED):
self.maximize()
- self.content_stack.set_visible_child(self._connection_panel)
+ self.panel_stack.set_visible_child(self._server_panel)
if self._settings.get_boolean(Window.SETTING_CONNECTED):
self._connect()
@@ -344,8 +340,7 @@ class Window(Adw.ApplicationWindow):
self.toolbar_view.add_top_bar(self.headerbar)
self.toolbar_view.remove(panel.get_headerbar_standalone())
- def on_connection_panel_connection_changed(self, widget, host, port,
- password):
+ def on_server_panel_connection_changed(self, widget, host, port, password):
self._settings.set_string(Window.SETTING_HOST, host)
self._settings.set_int(Window.SETTING_PORT, port)
if use_keyring:
@@ -471,7 +466,7 @@ class Window(Adw.ApplicationWindow):
self._server_panel.set_output_devices(devices)
def on_mcg_load_playlist(self, playlist):
- self._playlist_panel.set_playlist(self._connection_panel.get_host(),
+ self._playlist_panel.set_playlist(self._server_panel.get_host(),
playlist)
def on_mcg_init_albums(self):
@@ -481,7 +476,7 @@ class Window(Adw.ApplicationWindow):
GObject.idle_add(self._library_panel.load_albums)
def on_mcg_load_albums(self, albums):
- self._library_panel.set_albums(self._connection_panel.get_host(),
+ self._library_panel.set_albums(self._server_panel.get_host(),
albums)
def on_mcg_load_albumart(self, album, data):
@@ -514,22 +509,21 @@ class Window(Adw.ApplicationWindow):
# Private methods
def _connect(self):
- self._connection_panel.set_sensitive(False)
+ self._server_panel.set_connection_sensitive(False)
self._set_headerbar_sensitive(False, True)
if self._mcg.is_connected():
self._mcg.disconnect()
self._settings.set_boolean(Window.SETTING_CONNECTED, False)
else:
- host = self._connection_panel.get_host()
- port = self._connection_panel.get_port()
- password = self._connection_panel.get_password()
+ host = self._server_panel.get_host()
+ port = self._server_panel.get_port()
+ password = self._server_panel.get_password()
self._mcg.connect(host, port, password)
self._settings.set_boolean(Window.SETTING_CONNECTED, True)
def _connect_connected(self):
self._headerbar_connected()
self._set_headerbar_sensitive(True, False)
- self.content_stack.set_visible_child(self.panel_stack)
self.panel_stack.set_visible_child(self._panels[self._settings.get_int(
Window.SETTING_PANEL)])
@@ -539,8 +533,8 @@ class Window(Adw.ApplicationWindow):
self._headerbar_disconnected()
self._set_headerbar_sensitive(False, False)
self._save_visible_panel()
- self.content_stack.set_visible_child(self._connection_panel)
- self._connection_panel.set_sensitive(True)
+ self.panel_stack.set_visible_child(self._server_panel)
+ self._server_panel.set_connection_sensitive(True)
def _fullscreen(self, fullscreened_new):
if fullscreened_new != self._state.get_property(