Adapt medium editor to track structure changes

This commit is contained in:
Elias Projahn 2021-04-08 14:07:02 +02:00
parent 3702c9ad79
commit 79c86cbb57

View file

@ -7,7 +7,7 @@ use glib::prelude::*;
use gtk::prelude::*; use gtk::prelude::*;
use gtk_macros::get_widget; use gtk_macros::get_widget;
use libadwaita::prelude::*; use libadwaita::prelude::*;
use musicus_backend::db::{generate_id, Medium}; use musicus_backend::db::{generate_id, Medium, Track};
use musicus_backend::import::ImportSession; use musicus_backend::import::ImportSession;
use std::cell::RefCell; use std::cell::RefCell;
use std::rc::Rc; use std::rc::Rc;
@ -22,9 +22,8 @@ pub struct MediumEditor {
name_entry: gtk::Entry, name_entry: gtk::Entry,
publish_switch: gtk::Switch, publish_switch: gtk::Switch,
status_page: libadwaita::StatusPage, status_page: libadwaita::StatusPage,
disc_status_page: libadwaita::StatusPage,
track_set_list: Rc<List>, track_set_list: Rc<List>,
// track_sets: RefCell<Vec<TrackSetData>>, track_sets: RefCell<Vec<TrackSetData>>,
} }
impl Screen<Arc<ImportSession>, Medium> for MediumEditor { impl Screen<Arc<ImportSession>, Medium> for MediumEditor {
@ -43,7 +42,6 @@ impl Screen<Arc<ImportSession>, Medium> for MediumEditor {
get_widget!(builder, gtk::Frame, frame); get_widget!(builder, gtk::Frame, frame);
get_widget!(builder, libadwaita::StatusPage, status_page); get_widget!(builder, libadwaita::StatusPage, status_page);
get_widget!(builder, gtk::Button, try_again_button); get_widget!(builder, gtk::Button, try_again_button);
get_widget!(builder, libadwaita::StatusPage, disc_status_page);
get_widget!(builder, gtk::Button, cancel_button); get_widget!(builder, gtk::Button, cancel_button);
let list = List::new(); let list = List::new();
@ -57,9 +55,8 @@ impl Screen<Arc<ImportSession>, Medium> for MediumEditor {
name_entry, name_entry,
publish_switch, publish_switch,
status_page, status_page,
disc_status_page,
track_set_list: list, track_set_list: list,
// track_sets: RefCell::new(Vec::new()), track_sets: RefCell::new(Vec::new()),
}); });
// Connect signals and callbacks // Connect signals and callbacks
@ -83,43 +80,43 @@ impl Screen<Arc<ImportSession>, Medium> for MediumEditor {
add_button.connect_clicked(clone!(@weak this => move |_| { add_button.connect_clicked(clone!(@weak this => move |_| {
spawn!(@clone this, async move { spawn!(@clone this, async move {
// if let Some(track_set) = push!(this.handle, TrackSetEditor, Arc::clone(&this.session)).await { if let Some(track_set) = push!(this.handle, TrackSetEditor, Arc::clone(&this.session)).await {
// let length = { let length = {
// let mut track_sets = this.track_sets.borrow_mut(); let mut track_sets = this.track_sets.borrow_mut();
// track_sets.push(track_set); track_sets.push(track_set);
// track_sets.len() track_sets.len()
// }; };
// this.track_set_list.update(length); this.track_set_list.update(length);
// } }
}); });
})); }));
// this.track_set_list.set_make_widget_cb(clone!(@weak this => move |index| { this.track_set_list.set_make_widget_cb(clone!(@weak this => move |index| {
// let track_set = &this.track_sets.borrow()[index]; let track_set = &this.track_sets.borrow()[index];
// let title = track_set.recording.work.get_title(); let title = track_set.recording.work.get_title();
// let subtitle = track_set.recording.get_performers(); let subtitle = track_set.recording.get_performers();
// let edit_image = gtk::Image::from_icon_name(Some("document-edit-symbolic")); let edit_image = gtk::Image::from_icon_name(Some("document-edit-symbolic"));
// let edit_button = gtk::Button::new(); let edit_button = gtk::Button::new();
// edit_button.set_has_frame(false); edit_button.set_has_frame(false);
// edit_button.set_valign(gtk::Align::Center); edit_button.set_valign(gtk::Align::Center);
// edit_button.set_child(Some(&edit_image)); edit_button.set_child(Some(&edit_image));
// let row = libadwaita::ActionRow::new(); let row = libadwaita::ActionRow::new();
// row.set_activatable(true); row.set_activatable(true);
// row.set_title(Some(&title)); row.set_title(Some(&title));
// row.set_subtitle(Some(&subtitle)); row.set_subtitle(Some(&subtitle));
// row.add_suffix(&edit_button); row.add_suffix(&edit_button);
// row.set_activatable_widget(Some(&edit_button)); row.set_activatable_widget(Some(&edit_button));
// edit_button.connect_clicked(clone!(@weak this => move |_| { edit_button.connect_clicked(clone!(@weak this => move |_| {
// TODO: Implement editing. // TODO: Implement editing.
// })); }));
// row.upcast() row.upcast()
// })); }));
try_again_button.connect_clicked(clone!(@weak this => move |_| { try_again_button.connect_clicked(clone!(@weak this => move |_| {
this.widget.set_visible_child_name("content"); this.widget.set_visible_child_name("content");
@ -136,72 +133,62 @@ impl Screen<Arc<ImportSession>, Medium> for MediumEditor {
impl MediumEditor { impl MediumEditor {
/// Save the medium and possibly upload it to the server. /// Save the medium and possibly upload it to the server.
async fn save(&self) -> Result<Medium> { async fn save(&self) -> Result<Medium> {
// let name = self.name_entry.get_text().to_string(); let name = self.name_entry.get_text().to_string();
// Create a new directory in the music library path for the imported medium. // Create a new directory in the music library path for the imported medium.
// let mut path = self.handle.backend.get_music_library_path().unwrap().clone(); let mut path = self.handle.backend.get_music_library_path().unwrap().clone();
// path.push(&name); path.push(&name);
// std::fs::create_dir(&path)?; std::fs::create_dir(&path)?;
// Convert the track set data to real track sets. // Convert the track set data to real track sets.
// let mut track_sets = Vec::new(); let mut tracks = Vec::new();
// let import_tracks = self.session.tracks(); let import_tracks = self.session.tracks();
// for track_set_data in &*self.track_sets.borrow() { for track_set_data in &*self.track_sets.borrow() {
// let mut tracks = Vec::new(); for track_data in &track_set_data.tracks {
// for track_data in &track_set_data.tracks {
// Copy the corresponding audio file to the music library. // Copy the corresponding audio file to the music library.
// let import_track = &import_tracks[track_data.track_source]; let import_track = &import_tracks[track_data.track_source];
// let mut track_path = path.clone(); let mut track_path = path.clone();
// track_path.push(import_track.path.file_name().unwrap()); track_path.push(import_track.path.file_name().unwrap());
// std::fs::copy(&import_track.path, &track_path)?; std::fs::copy(&import_track.path, &track_path)?;
// Create the real track. // Create the real track.
// let track = Track { let track = Track {
// work_parts: track_data.work_parts.clone(), recording: track_set_data.recording.clone(),
// path: track_path.to_str().unwrap().to_owned(), work_parts: track_data.work_parts.clone(),
// }; path: track_path.to_str().unwrap().to_owned(),
};
// tracks.push(track); tracks.push(track);
// } }
}
// let track_set = TrackSet { let medium = Medium {
// recording: track_set_data.recording.clone(), id: generate_id(),
// tracks, name: self.name_entry.get_text().to_string(),
// }; discid: Some(self.session.source_id().to_owned()),
tracks: tracks,
};
// track_sets.push(track_set); let upload = self.publish_switch.get_active();
// } if upload {
self.handle.backend.cl().post_medium(&medium).await?;
}
// let medium = Medium { self.handle.backend
// id: generate_id(), .db()
// name: self.name_entry.get_text().to_string(), .update_medium(medium.clone())
// discid: Some(self.session.source_id().to_owned()), .await?;
// tracks: track_sets,
// };
// let upload = self.publish_switch.get_active(); self.handle.backend.library_changed();
// if upload {
// self.handle.backend.cl().post_medium(&medium).await?;
// }
// self.handle.backend Ok(medium)
// .db()
// .update_medium(medium.clone())
// .await?;
// self.handle.backend.library_changed();
// Ok(medium)
todo!();
} }
} }