Supporter.
[dcpomatic.git] / src / wx / content_properties_dialog.cc
index 45593fd5b84921982d4658e948d7c5d19a50762a..0b9bd0bb85b8b88f36a18700384f0a8be74fe816 100644 (file)
 #include "lib/content.h"
 #include "lib/video_content.h"
 #include "lib/audio_content.h"
+#include "lib/single_stream_audio_content.h"
 #include <boost/algorithm/string.hpp>
 
 using std::string;
+using std::list;
+using std::pair;
 using boost::shared_ptr;
 using boost::dynamic_pointer_cast;
 
 ContentPropertiesDialog::ContentPropertiesDialog (wxWindow* parent, shared_ptr<Content> content)
-       : TableDialog (parent, _("Content Properties"), 2, false)
+       : TableDialog (parent, _("Content Properties"), 2, 1, false)
 {
        string n = content->path(0).string();
        boost::algorithm::replace_all (n, "&", "&&");
-       add_property (_("Filename"), std_to_wx (n));
+       add (_("Filename"), true);
+       add (new wxStaticText (this, wxID_ANY, std_to_wx (n)));
 
-       shared_ptr<VideoContent> video = dynamic_pointer_cast<VideoContent> (content);
-       if (video) {
-               add_property (
-                       _("Video length"),
-                       std_to_wx (raw_convert<string> (video->video_length ())) + " " + _("video frames")
-                       );
-               add_property (
-                       _("Video size"),
-                       std_to_wx (raw_convert<string> (video->video_size().width) + "x" + raw_convert<string> (video->video_size().height))
-                       );
-               add_property (
-                       _("Video frame rate"),
-                       std_to_wx (raw_convert<string> (video->video_frame_rate())) + " " + _("frames per second")
-                       );
+       list<pair<string, string> > properties = content->properties ();
+       for (list<pair<string, string> >::const_iterator i = properties.begin(); i != properties.end(); ++i) {
+               add (std_to_wx (i->first), true);
+               add (new wxStaticText (this, wxID_ANY, std_to_wx (i->second)));
        }
 
-       shared_ptr<AudioContent> audio = dynamic_pointer_cast<AudioContent> (content);
-       if (audio) {
-               add_property (
-                       _("Audio channels"),
-                       std_to_wx (raw_convert<string> (audio->audio_channels ()))
-                       );
-               add_property (
-                       _("Audio length"),
-                       std_to_wx (raw_convert<string> (audio->audio_length())) + " " + _("audio frames")
-                       );
-       }
-       
        layout ();
 }
-
-void
-ContentPropertiesDialog::add_property (wxString k, wxString v)
-{
-       add (k, true);
-       add (new wxStaticText (this, wxID_ANY, v));
-}