getting enough data to start a new project
[cascardo/movie.git] / gzv.py
diff --git a/gzv.py b/gzv.py
index 78f3929..318a0f8 100644 (file)
--- a/gzv.py
+++ b/gzv.py
@@ -66,11 +66,27 @@ class GladeLoader(object):
     def gtk_main(self, *args):
         gtk.main()
 
+class Project(object):
+    def __init__(self, image, width, height):
+        self.image = image
+        self.width = width
+        self.height = height
+
 class NewProject(GladeLoader):
     def __init__(self, parent=None):
         super(NewProject, self).__init__('gzv.glade', 'new-project')
+        self.dialog = self.wid('new-project')
         if parent:
-            self.wid('new-project').set_transient_for(parent)
+            self.dialog.set_transient_for(parent)
+
+    def get_project(self):
+        fname = self.wid('image').get_filename()
+        width = self.wid('width').get_text()
+        height = self.wid('height').get_text()
+        return Project(fname, width, height)
+
+    def destroy(self):
+        self.dialog.destroy()
 
 class Gzv(GladeLoader):
     def __init__(self):
@@ -123,12 +139,12 @@ class Gzv(GladeLoader):
         print args
 
     def new_project(self, button):
-        dialog = NewProject(self.window).wid('new-project')
+        proj = NewProject(self.window)
 
         # This '1' was defined in the glade file
-        if dialog.run() == 1:
-            pass
-        dialog.destroy()
+        if proj.dialog.run() == 1:
+            self.load_new_project(proj.get_project())
+        proj.destroy()
 
     def open_file_chooser(self, button):
         fc = gtk.FileChooserDialog(_('Choose a gzv project'), self.window,