mirror of
https://github.com/johrpan/musicus.git
synced 2025-10-26 03:47:23 +01:00
Compare commits
7 commits
3904b62c2c
...
48cfdd354a
| Author | SHA1 | Date | |
|---|---|---|---|
| 48cfdd354a | |||
| 91b68b48e6 | |||
| 3c65905a37 | |||
| 1252ca0a1b | |||
|
|
5917b0ac36 | ||
| 8903ce7d2c | |||
| 41c2a9c1fc |
10 changed files with 74 additions and 45 deletions
1
Cargo.lock
generated
1
Cargo.lock
generated
|
|
@ -1880,7 +1880,6 @@ dependencies = [
|
|||
"glib",
|
||||
"gstreamer-play",
|
||||
"gtk4",
|
||||
"lazy_static",
|
||||
"libadwaita",
|
||||
"log",
|
||||
"mpris-server",
|
||||
|
|
|
|||
|
|
@ -17,7 +17,6 @@ gettext-rs = { version = "0.7", features = ["gettext-system"] }
|
|||
glib = { version = "0.20", features = ["v2_84"] }
|
||||
gstreamer-play = "0.23"
|
||||
gtk = { package = "gtk4", version = "0.9", features = ["v4_18", "blueprint"] }
|
||||
lazy_static = "1"
|
||||
log = "0.4"
|
||||
mpris-server = "0.8"
|
||||
once_cell = "1"
|
||||
|
|
|
|||
|
|
@ -6,6 +6,14 @@
|
|||
font-size: smaller;
|
||||
}
|
||||
|
||||
.rounded-entry {
|
||||
border-radius: 999px;
|
||||
padding-left: 12px;
|
||||
padding-right: 12px;
|
||||
padding-top: 3px;
|
||||
padding-bottom: 3px;
|
||||
}
|
||||
|
||||
.searchbar .searchtag {
|
||||
background-color: alpha(currentColor, 0.1);
|
||||
border-radius: 100px;
|
||||
|
|
|
|||
|
|
@ -73,11 +73,15 @@ template $MusicusSearchPage: Adw.NavigationPage {
|
|||
]
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
Gtk.SearchEntry search_entry {
|
||||
placeholder-text: _("Enter composers, performers, works…");
|
||||
margin-top: 24;
|
||||
activate => $select() swapped;
|
||||
|
||||
styles [
|
||||
"rounded-entry"
|
||||
]
|
||||
}
|
||||
|
||||
Gtk.Stack stack {
|
||||
|
|
|
|||
|
|
@ -5,7 +5,7 @@
|
|||
"sdk": "org.gnome.Sdk",
|
||||
"sdk-extensions": [
|
||||
"org.freedesktop.Sdk.Extension.rust-stable",
|
||||
"org.freedesktop.Sdk.Extension.llvm18"
|
||||
"org.freedesktop.Sdk.Extension.llvm20"
|
||||
],
|
||||
"command": "musicus",
|
||||
"finish-args": [
|
||||
|
|
@ -20,7 +20,7 @@
|
|||
"--env=G_MESSAGES_DEBUG=none"
|
||||
],
|
||||
"build-options": {
|
||||
"append-path": "/usr/lib/sdk/rust-stable/bin:/usr/lib/sdk/llvm18/bin",
|
||||
"append-path": "/usr/lib/sdk/rust-stable/bin:/usr/lib/sdk/llvm20/bin",
|
||||
"build-args": [
|
||||
"--share=network"
|
||||
],
|
||||
|
|
@ -31,17 +31,6 @@
|
|||
}
|
||||
},
|
||||
"modules": [
|
||||
{
|
||||
"name": "blueprint-compiler",
|
||||
"buildsystem": "meson",
|
||||
"sources": [
|
||||
{
|
||||
"type": "git",
|
||||
"url": "https://gitlab.gnome.org/jwestman/blueprint-compiler.git",
|
||||
"tag": "v0.16.0"
|
||||
}
|
||||
]
|
||||
},
|
||||
{
|
||||
"name": "musicus",
|
||||
"buildsystem": "meson",
|
||||
|
|
|
|||
|
|
@ -5,7 +5,7 @@
|
|||
"sdk": "org.gnome.Sdk",
|
||||
"sdk-extensions": [
|
||||
"org.freedesktop.Sdk.Extension.rust-stable",
|
||||
"org.freedesktop.Sdk.Extension.llvm18"
|
||||
"org.freedesktop.Sdk.Extension.llvm20"
|
||||
],
|
||||
"command": "musicus",
|
||||
"finish-args": [
|
||||
|
|
@ -20,7 +20,7 @@
|
|||
"--env=G_MESSAGES_DEBUG=none"
|
||||
],
|
||||
"build-options": {
|
||||
"append-path": "/usr/lib/sdk/rust-stable/bin:/usr/lib/sdk/llvm18/bin",
|
||||
"append-path": "/usr/lib/sdk/rust-stable/bin:/usr/lib/sdk/llvm20/bin",
|
||||
"build-args": [
|
||||
"--share=network"
|
||||
],
|
||||
|
|
|
|||
16
po/de.po
16
po/de.po
|
|
@ -8,7 +8,7 @@ msgid ""
|
|||
msgstr ""
|
||||
"Project-Id-Version: \n"
|
||||
"Report-Msgid-Bugs-To: \n"
|
||||
"POT-Creation-Date: 2025-04-27 17:54+0200\n"
|
||||
"POT-Creation-Date: 2025-05-30 15:27+0200\n"
|
||||
"PO-Revision-Date: 2025-04-27 18:23+0200\n"
|
||||
"Last-Translator: elias@johrpan.de\n"
|
||||
"Language-Team: German <translation-team-de@lists.sourceforge.net>\n"
|
||||
|
|
@ -818,7 +818,7 @@ msgstr "Bibliothek exportieren"
|
|||
msgid "Exporting music library to {}"
|
||||
msgstr "Bibliothek wird nach {} exportiert"
|
||||
|
||||
#: src/library_manager.rs:234 src/window.rs:282
|
||||
#: src/library_manager.rs:234 src/window.rs:305
|
||||
msgid "Updating metadata"
|
||||
msgstr "Metadaten werden aktualisiert"
|
||||
|
||||
|
|
@ -826,19 +826,23 @@ msgstr "Metadaten werden aktualisiert"
|
|||
msgid "Updating music library"
|
||||
msgstr "Musikbibliothek wird aktualisiert"
|
||||
|
||||
#: src/window.rs:167
|
||||
#: src/window.rs:166
|
||||
msgid "Currently playing music"
|
||||
msgstr "Musik wird abgespielt"
|
||||
|
||||
#: src/window.rs:190
|
||||
msgid "Close window?"
|
||||
msgstr "Fenster schließen?"
|
||||
|
||||
#: src/window.rs:169
|
||||
#: src/window.rs:192
|
||||
msgid "There are ongoing processes that will be canceled."
|
||||
msgstr "Es gibt laufende Prozesse, die abgebrochen werden."
|
||||
|
||||
#: src/window.rs:174
|
||||
#: src/window.rs:197
|
||||
msgid "Keep open"
|
||||
msgstr "Nicht schließen"
|
||||
|
||||
#: src/window.rs:175
|
||||
#: src/window.rs:198
|
||||
msgid "Close window"
|
||||
msgstr "Fenster schließen"
|
||||
|
||||
|
|
|
|||
|
|
@ -8,7 +8,7 @@ msgid ""
|
|||
msgstr ""
|
||||
"Project-Id-Version: PACKAGE VERSION\n"
|
||||
"Report-Msgid-Bugs-To: \n"
|
||||
"POT-Creation-Date: 2025-04-27 17:54+0200\n"
|
||||
"POT-Creation-Date: 2025-05-30 15:27+0200\n"
|
||||
"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
|
||||
"Last-Translator: FULL NAME <EMAIL@ADDRESS>\n"
|
||||
"Language-Team: LANGUAGE <LL@li.org>\n"
|
||||
|
|
@ -784,7 +784,7 @@ msgstr ""
|
|||
msgid "Exporting music library to {}"
|
||||
msgstr ""
|
||||
|
||||
#: src/library_manager.rs:234 src/window.rs:282
|
||||
#: src/library_manager.rs:234 src/window.rs:305
|
||||
msgid "Updating metadata"
|
||||
msgstr ""
|
||||
|
||||
|
|
@ -792,18 +792,22 @@ msgstr ""
|
|||
msgid "Updating music library"
|
||||
msgstr ""
|
||||
|
||||
#: src/window.rs:167
|
||||
#: src/window.rs:166
|
||||
msgid "Currently playing music"
|
||||
msgstr ""
|
||||
|
||||
#: src/window.rs:190
|
||||
msgid "Close window?"
|
||||
msgstr ""
|
||||
|
||||
#: src/window.rs:169
|
||||
#: src/window.rs:192
|
||||
msgid "There are ongoing processes that will be canceled."
|
||||
msgstr ""
|
||||
|
||||
#: src/window.rs:174
|
||||
#: src/window.rs:197
|
||||
msgid "Keep open"
|
||||
msgstr ""
|
||||
|
||||
#: src/window.rs:175
|
||||
#: src/window.rs:198
|
||||
msgid "Close window"
|
||||
msgstr ""
|
||||
|
|
|
|||
27
src/util.rs
27
src/util.rs
|
|
@ -2,27 +2,26 @@ pub mod activatable_row;
|
|||
pub mod drag_widget;
|
||||
pub mod error_dialog;
|
||||
|
||||
use std::sync::LazyLock;
|
||||
|
||||
use gettextrs::gettext;
|
||||
use gtk::glib::{self, clone};
|
||||
use lazy_static::lazy_static;
|
||||
|
||||
use error_dialog::ErrorDialog;
|
||||
|
||||
lazy_static! {
|
||||
/// The user's language code.
|
||||
pub static ref LANG: String = {
|
||||
let lang = match glib::language_names().first() {
|
||||
Some(language_name) => match language_name.split('_').next() {
|
||||
Some(lang) => lang.to_string(),
|
||||
None => "generic".to_string(),
|
||||
},
|
||||
/// The user's language code.
|
||||
pub static LANG: LazyLock<String> = LazyLock::new(|| {
|
||||
let lang = match glib::language_names().first() {
|
||||
Some(language_name) => match language_name.split('_').next() {
|
||||
Some(lang) => lang.to_string(),
|
||||
None => "generic".to_string(),
|
||||
};
|
||||
|
||||
log::info!("Intialized user language to '{lang}'.");
|
||||
lang
|
||||
},
|
||||
None => "generic".to_string(),
|
||||
};
|
||||
}
|
||||
|
||||
log::info!("Intialized user language to '{lang}'.");
|
||||
lang
|
||||
});
|
||||
|
||||
/// Create and show an error toast. This will also log the error to the console.
|
||||
pub fn error_toast(msgid: &str, err: anyhow::Error, toast_overlay: &adw::ToastOverlay) {
|
||||
|
|
|
|||
|
|
@ -1,4 +1,7 @@
|
|||
use std::{cell::RefCell, path::Path};
|
||||
use std::{
|
||||
cell::{Cell, RefCell},
|
||||
path::Path,
|
||||
};
|
||||
|
||||
use adw::{prelude::*, subclass::prelude::*};
|
||||
use anyhow::{anyhow, Result};
|
||||
|
|
@ -31,6 +34,7 @@ mod imp {
|
|||
pub library: RefCell<Option<Library>>,
|
||||
pub player: Player,
|
||||
pub process_manager: ProcessManager,
|
||||
pub inhibitor_cookie: Cell<Option<u32>>,
|
||||
|
||||
#[template_child]
|
||||
pub toast_overlay: TemplateChild<adw::ToastOverlay>,
|
||||
|
|
@ -148,6 +152,25 @@ mod imp {
|
|||
let obj = self.obj().to_owned();
|
||||
self.player.connect_raise(move |_| obj.present());
|
||||
|
||||
let obj = self.obj().to_owned();
|
||||
self.player.connect_playing_notify(move |player| {
|
||||
if let Some(app) = obj.application() {
|
||||
if let Some(cookie) = obj.imp().inhibitor_cookie.take() {
|
||||
app.uninhibit(cookie);
|
||||
};
|
||||
|
||||
if player.playing() {
|
||||
let cookie = app.inhibit(
|
||||
Some(&obj),
|
||||
gtk::ApplicationInhibitFlags::SUSPEND,
|
||||
Some(&gettext("Currently playing music")),
|
||||
);
|
||||
|
||||
obj.imp().inhibitor_cookie.set(Some(cookie));
|
||||
}
|
||||
}
|
||||
});
|
||||
|
||||
let settings = gio::Settings::new(config::APP_ID);
|
||||
let library_path = settings.string("library-path").to_string();
|
||||
if !library_path.is_empty() {
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue