fix alignment of meter tick
[ardour.git] / gtk2_ardour / sfdb_ui.h
index 249ebf3535834d6d49662c4b8c0578abc6cc535f..5d8decddf4dcd5d7ad905dd910797946d32a0182 100644 (file)
@@ -46,7 +46,7 @@
 #include "ardour/audiofilesource.h"
 #include "ardour/session_handle.h"
 
-#include "ardour_dialog.h"
+#include "ardour_window.h"
 #include "editing.h"
 #include "audio_clock.h"
 
@@ -110,7 +110,7 @@ class SoundFileBox : public Gtk::VBox, public ARDOUR::SessionHandlePtr
        void stop_audition ();
 };
 
-class SoundFileBrowser : public ArdourDialog
+class SoundFileBrowser : public ArdourWindow
 {
   private:
        class FoundTagColumns : public Gtk::TreeModel::ColumnRecord
@@ -128,12 +128,20 @@ class SoundFileBrowser : public ArdourDialog
                Gtk::TreeModelColumn<std::string> uri;
                Gtk::TreeModelColumn<std::string> filename;
                Gtk::TreeModelColumn<std::string> duration;
+               Gtk::TreeModelColumn<std::string> filesize;
+               Gtk::TreeModelColumn<std::string> smplrate;
+               Gtk::TreeModelColumn<std::string> license;
+               Gtk::TreeModelColumn<bool>        started;
 
                FreesoundColumns() {
                        add(id); 
                        add(filename); 
                        add(uri);
                        add(duration);
+                       add(filesize);
+                       add(smplrate);
+                       add(license);
+                       add(started);
                }
        };
 
@@ -143,12 +151,17 @@ class SoundFileBrowser : public ArdourDialog
        FreesoundColumns freesound_list_columns;
        Glib::RefPtr<Gtk::ListStore> freesound_list;
 
-       Gtk::Button freesound_stop_btn;
+       Gtk::Button freesound_more_btn;
+       Gtk::Button freesound_similar_btn;
 
+       void handle_freesound_results(std::string theString);
   public:
-       SoundFileBrowser (Gtk::Window& parent, std::string title, ARDOUR::Session* _s, bool persistent);
+       SoundFileBrowser (std::string title, ARDOUR::Session* _s, bool persistent);
        virtual ~SoundFileBrowser ();
 
+        int run ();
+        int status () const { return _status; }
+        
        virtual void set_session (ARDOUR::Session*);
        std::vector<std::string> get_paths ();
 
@@ -164,23 +177,19 @@ class SoundFileBrowser : public ArdourDialog
 
        Gtk::Entry freesound_entry;
        Gtk::ComboBoxText freesound_sort;
-       Gtk::SpinButton freesound_page;
-       
+
        Gtk::Button freesound_search_btn;
        Gtk::TreeView freesound_list_view;
-       Gtk::ProgressBar freesound_progress_bar;
-
-       bool freesound_search_cancel;
-       bool freesound_download_cancel;
+       Gtk::Notebook notebook;
 
        void freesound_search();
+       void refresh_display(std::string ID, std::string file);
        
-#ifdef FREESOUND
-       Mootcher *mootcher;
-#endif
-
   protected:
        bool resetting_ourselves;
+       int matches;
+        int _status;
+        bool _done;
 
        Gtk::FileFilter audio_and_midi_filter;
        Gtk::FileFilter audio_filter;
@@ -188,10 +197,14 @@ class SoundFileBrowser : public ArdourDialog
        Gtk::FileFilter custom_filter;
        Gtk::FileFilter matchall_filter;
        Gtk::HBox hpacker;
+        Gtk::VBox vpacker;
+
+        Gtk::Button ok_button;
+        Gtk::Button cancel_button;
+        Gtk::Button apply_button;
 
        static std::string persistent_folder;
 
-       Gtk::Notebook notebook;
 
        GainMeter* gm;
        Gtk::VBox meter_packer;
@@ -211,25 +224,30 @@ class SoundFileBrowser : public ArdourDialog
        void freesound_list_view_selected ();
        void freesound_list_view_activated (const Gtk::TreeModel::Path& path, Gtk::TreeViewColumn*);
        void freesound_search_clicked ();
-       void freesound_stop_clicked ();
+       void freesound_more_clicked ();
+       void freesound_similar_clicked ();
+       int freesound_page;
        
        void chooser_file_activated ();
+       std::string freesound_get_audio_file(Gtk::TreeIter iter);
 
        bool on_audio_filter (const Gtk::FileFilter::Info& filter_info);
        bool on_midi_filter (const Gtk::FileFilter::Info& filter_info);
        bool on_audio_and_midi_filter (const Gtk::FileFilter::Info& filter_info);
 
+        void set_action_sensitive (bool);
+
        virtual bool reset_options() { return true; }
 
   protected:
        void on_show();
-
+        virtual void do_something (int action);
 };
 
 class SoundFileChooser : public SoundFileBrowser
 {
   public:
-       SoundFileChooser (Gtk::Window& parent, std::string title, ARDOUR::Session* _s = 0);
+       SoundFileChooser (std::string title, ARDOUR::Session* _s = 0);
        virtual ~SoundFileChooser () {};
 
        std::string get_filename ();
@@ -242,7 +260,7 @@ class SoundFileOmega : public SoundFileBrowser
 {
 
   public:
-       SoundFileOmega (Gtk::Window& parent, std::string title, ARDOUR::Session* _s, 
+       SoundFileOmega (std::string title, ARDOUR::Session* _s, 
                        uint32_t selected_audio_tracks, uint32_t selected_midi_tracks,
                        bool persistent,
                        Editing::ImportMode mode_hint = Editing::ImportAsTrack);
@@ -286,6 +304,8 @@ class SoundFileOmega : public SoundFileBrowser
        bool reset_options ();
        void reset_options_noret ();
        bool bad_file_message ();
+
+        void do_something (int action);
 };
 
 #endif // __ardour_sfdb_ui_h__