mirror of
https://github.com/johrpan/musicus.git
synced 2025-10-26 11:47:25 +01:00
This commit (tries to) remove all code for synchronyzing to a music metadata server. Because the intended use cases of the application have shifted over time, this isn't a central feature anymore. However, it may well be decided to reintroduce the functionality at some point in the future.
114 lines
3 KiB
Rust
114 lines
3 KiB
Rust
use crate::navigator::{NavigationHandle, Screen};
|
|
use crate::widgets::{Editor, EntryRow, Section, Widget};
|
|
use anyhow::Result;
|
|
use gettextrs::gettext;
|
|
use glib::clone;
|
|
use gtk::prelude::*;
|
|
use musicus_backend::db::{generate_id, Instrument};
|
|
use std::rc::Rc;
|
|
|
|
/// A dialog for creating or editing a instrument.
|
|
pub struct InstrumentEditor {
|
|
handle: NavigationHandle<Instrument>,
|
|
|
|
/// The ID of the instrument that is edited or a newly generated one.
|
|
id: String,
|
|
|
|
editor: Editor,
|
|
name: EntryRow,
|
|
}
|
|
|
|
impl Screen<Option<Instrument>, Instrument> for InstrumentEditor {
|
|
/// Create a new instrument editor and optionally initialize it.
|
|
fn new(instrument: Option<Instrument>, handle: NavigationHandle<Instrument>) -> Rc<Self> {
|
|
let editor = Editor::new();
|
|
editor.set_title("Instrument/Role");
|
|
|
|
let list = gtk::ListBoxBuilder::new()
|
|
.selection_mode(gtk::SelectionMode::None)
|
|
.build();
|
|
|
|
let name = EntryRow::new(&gettext("Name"));
|
|
list.append(&name.widget);
|
|
|
|
let section = Section::new(&gettext("General"), &list);
|
|
editor.add_content(§ion.widget);
|
|
|
|
let id = match instrument {
|
|
Some(instrument) => {
|
|
name.set_text(&instrument.name);
|
|
instrument.id
|
|
}
|
|
None => generate_id(),
|
|
};
|
|
|
|
let this = Rc::new(Self {
|
|
handle,
|
|
id,
|
|
editor,
|
|
name,
|
|
});
|
|
|
|
// Connect signals and callbacks
|
|
|
|
this.editor.set_back_cb(clone!(@weak this => move || {
|
|
this.handle.pop(None);
|
|
}));
|
|
|
|
this.editor.set_save_cb(clone!(@weak this => move || {
|
|
spawn!(@clone this, async move {
|
|
this.editor.loading();
|
|
match this.save().await {
|
|
Ok(instrument) => {
|
|
this.handle.pop(Some(instrument));
|
|
}
|
|
Err(err) => {
|
|
let description = gettext!("Cause: {}", err);
|
|
this.editor.error(&gettext("Failed to save instrument!"), &description);
|
|
}
|
|
}
|
|
});
|
|
}));
|
|
|
|
this.name
|
|
.entry
|
|
.connect_changed(clone!(@weak this => move |_| this.validate()));
|
|
|
|
this.validate();
|
|
|
|
this
|
|
}
|
|
}
|
|
|
|
impl InstrumentEditor {
|
|
/// Validate inputs and enable/disable saving.
|
|
fn validate(&self) {
|
|
self.editor.set_may_save(!self.name.get_text().is_empty());
|
|
}
|
|
|
|
/// Save the instrument.
|
|
async fn save(&self) -> Result<Instrument> {
|
|
let name = self.name.get_text();
|
|
|
|
let instrument = Instrument {
|
|
id: self.id.clone(),
|
|
name,
|
|
};
|
|
|
|
self.handle
|
|
.backend
|
|
.db()
|
|
.update_instrument(instrument.clone())
|
|
.await?;
|
|
|
|
self.handle.backend.library_changed();
|
|
|
|
Ok(instrument)
|
|
}
|
|
}
|
|
|
|
impl Widget for InstrumentEditor {
|
|
fn get_widget(&self) -> gtk::Widget {
|
|
self.editor.widget.clone().upcast()
|
|
}
|
|
}
|