change property type dialog to use dropdown (has bug with popover autohide, but added...
[roobuilder] / src / JsRender / NodeToGlade.vala
index f42279b..874983f 100644 (file)
@@ -75,14 +75,16 @@ public class JsRender.NodeToGlade : Object {
        public Xml.Doc* mungeNode()
        {
                Xml.Doc* doc;
+               var is_top = false;
                if (this.parent == null) {
+                       is_top = true;
                        doc = new Xml.Doc("1.0");
 
                        var inf = this.create_element("interface");
                        doc->set_root_element(inf);
                        var req = this.create_element("requires");
                        req->set_prop("lib", "gtk+");
-                       req->set_prop("version", "3.12");
+                       req->set_prop("version", "4.1");
                        inf->add_child(req);
                        this.parent = inf;
                } else {
@@ -90,85 +92,81 @@ public class JsRender.NodeToGlade : Object {
                }
                var cls = this.node.fqn().replace(".", "");
                
-               var girdata = Palete.Gir.factoryFqn(this.project, this.node.fqn());
-               
-               
-               
-               /// check if it's a GtkWidget?
-               // maybe not?
-               // how are models handled?
-               
-               
-               //var b = new global::Gtk.Builder();
-
-               // this might be needed if we are using non-Gtk elements?
-               //var gtype = b.get_type_from_name(cls);
-               //GLib.debug ("Type: %s ?= %s\n", this.node.fqn(), gtype.name());
-
-               
-               /*
-               var ns = this.node.fqn().split(".")[0];
-               if (ns == "Clutter") {
-                       return "";
+               var gdata = Palete.Gir.factoryFqn(this.project, this.node.fqn());
+               if (gdata == null || !gdata.inherits.contains("Gtk.Buildable")) {
+                       return doc;
                }
-               //if (ns == "GtkClutter") {
-               //      return "";
-               //}
-               if (ns == "WebKit") {
-                       return "";
+               if (gdata.inherits.contains("Gtk.Native")&& !is_top) {
+                       return doc;
+               }
+               // what namespaces are supported
+               switch(this.node.NS) {
+                       case "Gtk":
+                       case "Webkit": //??
+                       case "Adw": // works if you call adw.init() in main!
+                               break;
+                       default:
+                               return doc;
                }
-               */
-               /*
                
-               switch(cls) {
-                       // things we can not do yet...
-                       
-                       //case "GtkView": // SourceView?
-                       case "GtkTreeStore": // top level.. - named and referenced
-                       case "GtkListStore": // top level.. - named and referenced
-                       case "GtkTreeViewColumn": // part of liststore?!?!
-                       case "GtkMenu": // top level..
-                       case "GtkCellRendererText":
-                       case "GtkSourceBuffer":                         
-                       case "GtkClutterActor"://fixme..
-                       ///case "GtkClutterEmbed"://fixme..
-                               return "";
+               // other problems!!!
+               
+               if (gdata.fqn() == ("Gtk.ListStore")) {
+                       return doc;
                }
-               */
                
                // should really use GXml... 
                var obj = this.create_element("object");
-               var id = this.node.uid();
-               obj->set_prop("class", cls);
-               obj->set_prop("id", id);
+               //var id = this.node.uid();
+               var skip_props = false;
+               if (gdata.inherits.contains("Gtk.Native")) {
+                        
+                       obj->set_prop("class", "GtkFrame");
+                       skip_props = true;
+               } else {
+               
+                       obj->set_prop("class", cls);
+               }
+               obj->set_prop("id", "w" + this.node.oid.to_string());
                this.parent->add_child(obj);
                // properties..
                var props = Palete.Gir.factoryFqn(this.project, this.node.fqn()).props;
  
               
                var pviter = props.map_iterator();
-               while (pviter.next()) {
+               while (!skip_props && pviter.next()) {
                        
-                       GLib.debug ("Check: " +cls + "::(" + pviter.get_value().propertyof + ")" + pviter.get_key() + " " );
+                       //GLib.debug ("Check: " +cls + "::(" + pviter.get_value().propertyof + ")" + pviter.get_key() + " " );
                        
                // skip items we have already handled..
                if  (!this.node.has(pviter.get_key())) {
                                continue;
                        }
-                       var k = pviter.get_key();
-                       var val = this.node.get(pviter.get_key()).strip();
-                       var prop = this.create_element("property");
-                       prop->set_prop("name", k);
-                       switch (k) { 
-                               case "orientation":
-                                       var bits = val.split(".");
-                                       val = bits.length > 2 ? bits[2].down() : "vertical"; // ??
-                                       break;
+                       var k = pviter.get_key();       
+                       var prop = props.get(k);
+                       var val = this.node.get(pviter.get_key()).strip();      
+                       // for Enums - we change it to lowercase, and remove all the previous bits.. hopefully might work.
+                       if (prop.type.contains(".") && val.contains(".")) {
+                               var typ =  Palete.Gir.factoryFqn(this.project, prop.type);
+                               if (typ.nodetype == "Enum") {
+                                        var bits = val.split(".");
+                                        val = bits[bits.length-1].down();
+                               }
+                       }
+                       
+                       //  value for model seems to cause problems...(it's ok as a property?)
+                       if (k == "model") {
+                               continue;
                        }
+
+
+                       var domprop = this.create_element("property");
+                       domprop->set_prop("name", k);
+                        
                        
                        
-                       prop->add_child(new Xml.Node.text(val));
-                       obj->add_child(prop); 
+                       domprop->add_child(new Xml.Node.text(val));
+                       obj->add_child(domprop); 
         }
                // packing???
 /*
@@ -183,9 +181,9 @@ public class JsRender.NodeToGlade : Object {
                }       */
                // children..
 
-               
-               for (var i = 0; i < this.node.items.size; i++ ) {
-                       var cn = this.node.items.get(i);
+               var items = this.node.readItems();
+               for (var i = 0; i < items.size; i++ ) {
+                       var cn = items.get(i);
                        var child  = this.create_element("child");
                        if (cls == "GtkWindow" && cn.fqn() == "Gtk.HeaderBar") {
                                child->set_prop("type", "titlebar");
@@ -205,125 +203,7 @@ public class JsRender.NodeToGlade : Object {
 
        }
         
-        /*
-       public string packString()
-       {
-               
-               
-               
-               
-               // pack is part of the parent element..
-               var p = node.parent;
-               string[]  pk= { "add" };
-               var pfqn = "Gtk.Box";
-               if (p != null) {
-                       pfqn  = p.fqn();
-                       if (this.node.props.get("* pack") == null) {
-                               return "";
-                       }
-                       pk = this.node.get("* pack").split(",");
-               } else {
-                       if (this.node.props.get("* pack") != null) {
-                               pk = this.node.get("* pack").split(",");
-                       }
-                       
-               }
-               
-               if (pfqn == null) {
-                       return "";
-               }
-               if (pfqn == "Gtk.ScrolledWindow") {
-                       return "";
-               }
-               var p_parts =pfqn.split(".");
-
-               var ns = p_parts[0];
-               var gir =  Palete.Gir.factory(this.project, ns);
-               var cls = gir.classes.get(p_parts[1]);
-               var mdef = cls.methods.get(pk[0]);
-               if (mdef == null) {
-                       GLib.debug ("could not find method : %s\n", pk[0]);
-                       return "";
-               }
-               /*
-               var generator = new Json.Generator ();
-               var n = new Json.Node(Json.NodeType.OBJECT);
-               n.set_object(mdef.toJSON());
-               generator.set_root(n);
-               generator.indent = 4;
-               generator.pretty = true;
-                   
-               GLib.debug print(generator.to_data(null));
-               */
-               /*
-               string[]  pbody  = {};
-               switch(pk[0]) {
-
-                       case "pack_start":
-                               pbody += @"$pad    <property name=\"pack_type\">start</property>\n";
-                               break;
-                       
-                       case "pack_end":
-                               pbody += @"$pad    <property name=\"pack_type\">start</property>\n";
-                               break;
-                               
-                       case "add":
-                               //pbody += @"$pad    <property name=\"pack_type\">start</property>\n";
-                                pbody += @"$pad    <property name=\"expand\">True</property>\n";
-                               pbody += @"$pad    <property name=\"fill\">True</property>\n";
-                               //pbody += @"$pad    <property name=\"position\">1</property>\n";
-                               var pack = @"$pad<packing>\n" +
-                                       string.joinv("", pbody) + 
-                                               @"$pad</packing>\n";
-                               return pack;
-                
-                       case "set_model":
-                               GLib.debug ("set_model not handled yet..");
-                               return "";
-                       
-                       default:
-                               GLib.debug  ("unknown pack type: %s", pk[0]);
-                               return "";
-                               
-               }
-                       
-
-                
-               for (var i = 2; i < mdef.paramset.params.size; i++) {
-                       var poff = i - 1;
-                       if (poff > (pk.length-1)) {
-                               break;
-                       }
-                       
-                       var key = mdef.paramset.params.get(i).name;
-                       var val = pk[poff];
-                       pbody += @"$pad    <property name=\"$key\">$val</property>\n";
-               
-               }
-            
-               if (pbody.length < 1) {
-                       /*var generator = new Json.Generator ();
-                       var n = new Json.Node(Json.NodeType.OBJECT);
-                       n.set_object(mdef.toJSON());
-                       generator.set_root(n);
-                       generator.indent = 4;
-                       generator.pretty = true;
-                           
-                       print(generator.to_data(null));
-                       */ 
-                       /*
-                       GLib.debug ("skip - packing - no arguments (" + pk[0] + ")\n");
-                       return "";
-               }
-               
-               var pack = @"$pad<packing>\n" +
-                               string.joinv("", pbody) + 
-                               @"$pad</packing>\n";
-               return pack;
-
-       }
-       */
+