Add UTC-3:30 timezone to cinema (#831).
[dcpomatic.git] / src / wx / content_properties_dialog.cc
index 7fb0cccbab2e42962a281c685148bcb851a8bfeb..37f96c156aeeef50977198ea7313f00b7742c247 100644 (file)
 #include "lib/audio_content.h"
 #include "lib/single_stream_audio_content.h"
 #include <boost/algorithm/string.hpp>
+#include <boost/foreach.hpp>
 
 using std::string;
+using std::list;
+using std::pair;
+using std::map;
 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")
-                       );
+       map<string, list<Content::UserProperty> > grouped;
+       BOOST_FOREACH (Content::UserProperty i, content->user_properties()) {
+               if (grouped.find(i.category) == grouped.end()) {
+                       grouped[i.category] = list<Content::UserProperty> ();
+               }
+               grouped[i.category].push_back (i);
        }
 
-       /* XXX: this could be better wrt audio streams */
+       for (map<string, list<Content::UserProperty> >::const_iterator i = grouped.begin(); i != grouped.end(); ++i) {
 
-       shared_ptr<SingleStreamAudioContent> single = dynamic_pointer_cast<SingleStreamAudioContent> (content);
-       if (single) {
-               add_property (
-                       _("Audio channels"),
-                       std_to_wx (raw_convert<string> (single->audio_stream()->channels ()))
-                       );
+               wxStaticText* m = new wxStaticText (this, wxID_ANY, std_to_wx (i->first));
+               wxFont font (*wxNORMAL_FONT);
+               font.SetWeight (wxFONTWEIGHT_BOLD);
+               m->SetFont (font);
+
+               add_spacer ();
+               add_spacer ();
+               add (m, false);
+               add_spacer ();
+
+               BOOST_FOREACH (Content::UserProperty j, i->second) {
+                       add (std_to_wx (j.key), true);
+                       add (new wxStaticText (this, wxID_ANY, std_to_wx (j.value + " " + j.unit)));
+               }
        }
 
        layout ();
 }
-
-void
-ContentPropertiesDialog::add_property (wxString k, wxString v)
-{
-       add (k, true);
-       add (new wxStaticText (this, wxID_ANY, v));
-}