src/Builder4/WindowLeftProps.bjs
[app.Builder.js] / src / Builder4 / WindowLeftProps.vala
1 static Xcls_LeftProps  _LeftProps;
2
3 public class Xcls_LeftProps : Object 
4 {
5     public Gtk.VBox el;
6     private Xcls_LeftProps  _this;
7
8     public static Xcls_LeftProps singleton()
9     {
10         if (_LeftProps == null) {
11             _LeftProps= new Xcls_LeftProps();
12         }
13         return _LeftProps;
14     }
15     public Xcls_AddPropertyPopup AddPropertyPopup;
16     public Xcls_EditProps EditProps;
17     public Xcls_view view;
18     public Xcls_model model;
19     public Xcls_keycol keycol;
20     public Xcls_keyrender keyrender;
21     public Xcls_valcol valcol;
22     public Xcls_valrender valrender;
23     public Xcls_valrendermodel valrendermodel;
24     public Xcls_ContextMenu ContextMenu;
25
26         // my vars (def)
27     public bool allow_edit;
28     public JsRender.JsRender file;
29     public signal bool stop_editor ();
30     public signal void show_editor (JsRender.JsRender file, JsRender.Node node, string type, string key);
31     public signal void changed ();
32     public signal void show_add_props (string type);
33     public Xcls_MainWindow main_window;
34     public JsRender.Node node;
35
36     // ctor 
37     public Xcls_LeftProps()
38     {
39         _this = this;
40         this.el = new Gtk.VBox( false   , 0 );
41
42         // my vars (dec)
43         this.allow_edit = false;
44         this.main_window = null;
45
46         // set gobject values
47         var child_0 = new Xcls_HBox2( _this );
48         child_0.ref();
49         this.el.pack_start (  child_0.el , false,true,0 );
50         var child_1 = new Xcls_EditProps( _this );
51         child_1.ref();
52         this.el.pack_end (  child_1.el , true,true,0 );
53     }
54
55     // user defined functions 
56     public              void before_edit ()
57     {
58     
59         print("before edit - stop editing\n");
60         
61       // these do not appear to trigger save...
62         _this.keyrender.el.stop_editing(false);
63         _this.keyrender.el.editable  =false;
64     
65         _this.valrender.el.stop_editing(false);
66         _this.valrender.el.editable  =false;    
67         
68         
69     // technicall stop the popup editor..
70     
71     }
72     public              string keySortFormat (string key) {
73         // listeners first - with 0
74         // specials
75         if (key[0] == '*') {
76             return "1 " + key;
77         }
78         // functions
79         
80         var bits = key.split(" ");
81         
82         if (key[0] == '|') {
83             return "2 " + bits[bits.length -1];
84         }
85         // signals
86         if (key[0] == '@') {
87             return "3 " + bits[bits.length -1];
88         }
89             
90         // props
91         if (key[0] == '#') {
92             return "4 " + bits[bits.length -1];
93         }
94         // the rest..
95         return "5 " + bits[bits.length -1];    
96     
97     
98     
99     }
100     public              void finish_editing () {
101          // 
102         this.before_edit();
103     }
104     public              bool startEditingValue ( Gtk.TreePath path) {
105     
106         // ONLY return true if editing is allowed - eg. combo..
107         
108                 print("start editing?\n");
109                 if (!this.stop_editor()) {
110                     print("stop editor failed\n");
111                     return false;
112                 }
113                 
114                 Gtk.TreeIter iter;
115     
116                 var mod = this.model.el;
117                 mod.get_iter (out iter, path);
118                  
119                 /*
120                     m.set(iter, 
121                             0, "listener",
122                             1, miter.get_key(),
123                             2, "<b>" + miter.get_key() + "</b>",
124                             3, miter.get_value()
125                         ); 
126                  
127                 */
128                 GLib.Value gval;
129                 mod.get_value(iter, 3 , out gval);
130                 var val = (string)gval;
131             
132                 mod.get_value(iter, 1 , out gval);
133                 var key = (string)gval;
134                 var type_ar = key.split(" ");
135                 
136                 
137                 
138                 mod.get_value(iter, 0 , out gval);
139                 var type = (string)gval;
140                 
141                
142                 
143                 var use_textarea = false;
144     
145                 //------------ things that require the text editor...
146                 
147                 if (type == "listener") {
148                     use_textarea = true;
149                 }
150                 if (key.length > 0 && key[0] == '|') { // user defined method
151                     use_textarea = true;
152                 }
153                 if (key.length > 0 && key[0] == '$') { // raw string
154                     use_textarea = true;
155                 }
156                 if (key.length > 0 && key == "* init") {
157                     use_textarea = true;
158                 }
159                 if (val.length > 40) { // long value...
160                     use_textarea = true;
161                 }
162                 
163                 
164                 
165                 if (use_textarea) {
166                     print("Call show editor\n");
167                     GLib.Timeout.add_full(GLib.Priority.DEFAULT,10 , () => {
168                         this.view.el.get_selection().select_path(path);
169                         
170                         this.show_editor(file, node, type, key);
171                         
172                         return false;
173                     });
174                    
175                     
176                     return false;
177                 }
178                 // others... - fill in options for true/false?
179                print("turn on editing %s \n" , mod.get_path(iter).to_string());
180                
181                    print (type_ar[0].up());
182                     if (type_ar.length > 1 && (
183                             type_ar[0].up() == "BOOLEAN"
184                             ||
185                             type_ar[0].up() == "BOOL"                        
186                         )) {
187                             print("start editing try/false)???");
188                             this.valrender.el.has_entry = false;
189                             string[] opts =  { "true", "false" };
190                             this.valrender.setOptions(opts);
191                             
192                             this.valrender.el.has_entry = false;
193                             this.valrender.el.editable = true;
194                              this.allow_edit  = true;
195                              GLib.Timeout.add_full(GLib.Priority.DEFAULT,100 , () => {
196                                  this.view.el.set_cursor_on_cell(
197                                     path,
198                                     this.valcol.el,
199                                     this.valrender.el,
200                                     true
201                                 );
202                                 return false;
203                             });
204                             return true;
205                     }
206                                           
207                     
208                
209                  string[] opts =  {  };
210                 this.valrender.setOptions(opts);
211                
212                GLib.Timeout.add_full(GLib.Priority.DEFAULT,10 , () => {
213                     
214                     // at this point - work out the type...
215                     // if its' a combo... then show the options..
216                     this.valrender.el.has_entry = true;
217                     
218                     this.valrender.el.editable = true;            
219                 
220                     
221                     this.allow_edit  = true;
222                     
223                     
224                     
225                     
226     
227                     this.view.el.set_cursor_on_cell(
228                         path,
229                         this.valcol.el,
230                         this.valrender.el,
231                         true
232                     );
233                     return false;
234                 });
235                 return false;
236             }
237     public              void load (JsRender.JsRender file, JsRender.Node? node) 
238     {
239         print("load leftprops\n");
240         this.before_edit();
241         this.node = node;
242         this.file = file;
243         
244      
245         this.model.el.clear();
246                   
247         //this.get('/RightEditor').el.hide();
248         if (node ==null) {
249             return ;
250         }
251          
252         
253     
254         //var provider = this.get('/LeftTree').getPaleteProvider();
255         Gtk.TreeIter iter;
256         
257         //typeof(string),  // 0 key type
258          //typeof(string),  // 1 key
259          //typeof(string),  // 2 key (display)
260          //typeof(string),  // 3 value
261          //typeof(string),  // 4 value (display)
262          //typeof(string),  // 5 both (tooltip)
263         
264         
265         
266         
267         // really need a way to sort the hashmap...
268         var m = this.model.el;
269         
270         var miter = node.listeners.map_iterator();
271         var i = 0;
272         
273         while(miter.next()) {
274             i++;
275             m.append(out iter,null);
276             
277             this.updateIter(iter,  "listener", miter.get_key(), miter.get_value());
278             
279              
280          }
281          
282           
283         miter = node.props.map_iterator();
284         
285         
286        while(miter.next()) {
287                i++;
288             m.append(out iter,null);
289              this.updateIter(iter,  "prop", miter.get_key(), miter.get_value());
290              
291        }
292        print("clear selection\n");
293        // clear selection?
294        this.model.el.set_sort_column_id(6,Gtk.SortType.ASCENDING); // sort by real key..
295        
296        this.view.el.get_selection().unselect_all();
297        
298            var pane = _this.main_window.editpane.el;
299         var try_size = (i * 25) + 60; // est. 20px per line + 40px header
300         
301         // max 80%...
302         pane.set_position( 
303              ((try_size * 1.0f) /  (pane.max_position * 1.0f))  > 0.8f  ? 
304             (int) (pane.max_position * 0.2f) :
305             pane.max_position-try_size);
306         
307        
308     }
309     public              string keyFormat (string val, string type) {
310         
311         // Glib.markup_escape_text(val);
312     
313         if (type == "listener") {
314             return "<span font_weight=\"bold\" color=\"#660000\">" + 
315                 GLib.Markup.escape_text(val) +
316                  "</span>";
317         }
318         // property..
319         if (val.length < 1) {
320             return "<span  color=\"#FF0000\">--empty--</span>";
321         }
322         
323         //@ = signal
324         //$ = property with 
325         //# - object properties
326         //* = special
327         // all of these... - display value is last element..
328         var ar = val.strip().split(" ");
329         
330         
331         var dval = GLib.Markup.escape_text(ar[ar.length-1]);
332         
333         
334         
335         
336         switch(val[0]) {
337             case '@': // signal // just bold balck?
338                 if (dval[0] == '@') {
339                     dval = dval.substring(1);
340                 }
341             
342                 return @"<span  font_weight=\"bold\">@ $dval</span>";        
343             case '#': // object properties?
344                 if (dval[0] == '#') {
345                     dval = dval.substring(1);
346                 }
347                 return @"<span  font_weight=\"bold\">$dval</span>";
348             case '*': // special
349                 if (dval[0] == '*') {
350                     dval = dval.substring(1);
351                 }
352                 return @"<span   color=\"#0000CC\" font_weight=\"bold\">$dval</span>";            
353             case '$':
354                 if (dval[0] == '$') {
355                     dval = dval.substring(1);
356                 }
357                 return @"<span   style=\"italic\">$dval</span>";
358            case '|': // user defined methods
359                 if (dval[0] == '|') {
360                     dval = dval.substring(1);
361                 }
362                 return @"<span color=\"#008000\" font_weight=\"bold\">$dval</span>";
363                 
364                   
365                 
366             default:
367                 return dval;
368         }
369           
370         
371     
372     }
373     public              void deleteSelected () {
374         
375             Gtk.TreeIter iter;
376             Gtk.TreeModel mod;
377             
378             var s = this.view.el.get_selection();
379             s.get_selected(out mod, out iter);
380                  
381                   
382             GLib.Value gval;
383             mod.get_value(iter, 0 , out gval);
384             var type = (string)gval;
385             
386             mod.get_value(iter, 1 , out gval);
387             var key = (string)gval;
388             
389             switch(type) {
390                 case "listener":
391                     this.node.listeners.remove(key);
392                     break;
393                     
394                 case "props":
395                     this.node.props.remove(key);
396                     break;
397             }
398             this.load(this.file, this.node);
399             
400             _this.changed();
401     }
402     public              void startEditingKey ( Gtk.TreePath path) {
403         
404          if (!this.stop_editor()) {
405             return;
406          }
407       
408         // others... - fill in options for true/false?
409         
410            
411         GLib.Timeout.add_full(GLib.Priority.DEFAULT,10 , () => {
412             this.allow_edit  = true;
413             this.keyrender.el.editable = true;
414          
415             this.view.el.set_cursor_on_cell(
416                 path,
417                 this.keycol.el,
418                 this.keyrender.el,
419                 true
420             );
421                    
422             return false;
423         });
424           
425         
426     }
427     public              void addProp (string in_type, string key, string value, string value_type) {
428           // info includes key, val, skel, etype..
429           //console.dump(info);
430             //type = info.type.toLowerCase();
431             //var data = this.toJS();
432               
433         var type = in_type == "signals" ? "listener" : in_type;
434           
435         var fkey = (value_type.length > 0 ? value_type + " " : "") + key;
436                   
437         if (type == "listener") {
438             if (this.node.listeners.has_key(key)) {
439                 return;
440             }
441             this.node.listeners.set(key,value);
442         } else  {
443         
444             if (this.node.props.has_key(fkey)) {
445                 return;
446             }
447             this.node.props.set(fkey,value);
448         }
449                
450           
451         // add a row???
452         this.load(this.file, this.node);
453         
454         
455         
456         /// need to find the row which I've just added..
457         
458         
459         var s = this.view.el.get_selection();
460         s.unselect_all();
461         
462         print("trying to find new iter");
463       
464         this.model.el.foreach((model, path, iter) => {
465             GLib.Value gval;
466         
467             this.model.el.get_value(iter, 0 , out gval);
468             if ((string)gval != type) {
469                 print("not type: %s = %s\n", (string)gval , type);
470                 return false;
471             }
472             this.model.el.get_value(iter, 1 , out gval);
473             if ((string)gval != fkey) {
474                 print("not key: %s = %s\n", (string)gval , fkey);
475                 return false;
476             }
477             // delay this?
478             GLib.Timeout.add_full(GLib.Priority.DEFAULT,40 , () => {
479             
480                 this.startEditingValue(this.model.el.get_path(iter));
481                 return false;
482             });
483             //s.select_iter(iter);
484             return true; 
485         });
486         
487         
488         
489                   
490     }
491     public              void updateIter (Gtk.TreeIter iter,  string type, string key, string value) {
492     
493         print("update Iter %s, %s\n", key,value);
494         //typeof(string),  // 0 key type
495          //typeof(string),  // 1 key
496          //typeof(string),  // 2 key (display)
497          //typeof(string),  // 3 value
498          //typeof(string),  // 4 value (display)
499          //typeof(string),  // 5 both (tooltip)
500          //typeof(string),  // 6 key (sort)
501         
502         var dl = value.strip().split("\n");
503     
504         var dis_val = dl.length > 1 ? (dl[0].strip()+ "...") : dl[0];
505         
506         if (type == "listener") {
507          
508            
509             
510             this.model.el.set(iter, 
511                     0, type,
512                 1, key,
513                 2, this.keyFormat(key ,type),
514                 3, value,
515                 4, dis_val,
516                 5, "<tt>" +  GLib.Markup.escape_text(key + " " +value) + "</tt>",
517                 6,  "0 " + key
518             ); 
519             return;
520         }
521         
522     
523     
524         this.model.el.set(iter, 
525                 0, "props",
526                 1, key,
527                 2,  this.keyFormat(key , "prop"),
528                 3, value,
529                 4, dis_val,
530                  5, "<tt>" + GLib.Markup.escape_text(key + " " + value) + "</tt>",
531                  6,  this.keySortFormat(key)
532             ); 
533     }
534     public class Xcls_HBox2 : Object 
535     {
536         public Gtk.HBox el;
537         private Xcls_LeftProps  _this;
538
539
540             // my vars (def)
541
542         // ctor 
543         public Xcls_HBox2(Xcls_LeftProps _owner )
544         {
545             _this = _owner;
546             this.el = new Gtk.HBox( true, 0 );
547
548             // my vars (dec)
549
550             // set gobject values
551             var child_0 = new Xcls_Button3( _this );
552             child_0.ref();
553             this.el.add (  child_0.el  );
554         }
555
556         // user defined functions 
557     }
558     public class Xcls_Button3 : Object 
559     {
560         public Gtk.Button el;
561         private Xcls_LeftProps  _this;
562
563
564             // my vars (def)
565
566         // ctor 
567         public Xcls_Button3(Xcls_LeftProps _owner )
568         {
569             _this = _owner;
570             this.el = new Gtk.Button();
571
572             // my vars (dec)
573
574             // set gobject values
575             var child_0 = new Xcls_HBox4( _this );
576             child_0.ref();
577             this.el.add (  child_0.el  );
578             var child_1 = new Xcls_AddPropertyPopup( _this );
579             child_1.ref();
580
581             // listeners 
582             this.el.button_press_event.connect( (self, ev) => {
583                 _this.before_edit();
584                 
585                     
586                 var p = _this.AddPropertyPopup;
587                 p.el.set_screen(Gdk.Screen.get_default());
588                 p.el.show_all();
589                  p.el.popup(null, null, null, ev.button, ev.time);
590                  return true;
591             });
592         }
593
594         // user defined functions 
595     }
596     public class Xcls_HBox4 : Object 
597     {
598         public Gtk.HBox el;
599         private Xcls_LeftProps  _this;
600
601
602             // my vars (def)
603
604         // ctor 
605         public Xcls_HBox4(Xcls_LeftProps _owner )
606         {
607             _this = _owner;
608             this.el = new Gtk.HBox( true, 0 );
609
610             // my vars (dec)
611
612             // set gobject values
613             var child_0 = new Xcls_Image5( _this );
614             child_0.ref();
615             this.el.add (  child_0.el  );
616             var child_1 = new Xcls_Label6( _this );
617             child_1.ref();
618             this.el.add (  child_1.el  );
619         }
620
621         // user defined functions 
622     }
623     public class Xcls_Image5 : Object 
624     {
625         public Gtk.Image el;
626         private Xcls_LeftProps  _this;
627
628
629             // my vars (def)
630
631         // ctor 
632         public Xcls_Image5(Xcls_LeftProps _owner )
633         {
634             _this = _owner;
635             this.el = new Gtk.Image();
636
637             // my vars (dec)
638
639             // set gobject values
640             this.el.stock = Gtk.STOCK_ADD;
641             this.el.icon_size = Gtk.IconSize.MENU;
642         }
643
644         // user defined functions 
645     }
646     public class Xcls_Label6 : Object 
647     {
648         public Gtk.Label el;
649         private Xcls_LeftProps  _this;
650
651
652             // my vars (def)
653
654         // ctor 
655         public Xcls_Label6(Xcls_LeftProps _owner )
656         {
657             _this = _owner;
658             this.el = new Gtk.Label( "Other" );
659
660             // my vars (dec)
661
662             // set gobject values
663         }
664
665         // user defined functions 
666     }
667     public class Xcls_AddPropertyPopup : Object 
668     {
669         public Gtk.Menu el;
670         private Xcls_LeftProps  _this;
671
672
673             // my vars (def)
674
675         // ctor 
676         public Xcls_AddPropertyPopup(Xcls_LeftProps _owner )
677         {
678             _this = _owner;
679             _this.AddPropertyPopup = this;
680             this.el = new Gtk.Menu();
681
682             // my vars (dec)
683
684             // set gobject values
685             var child_0 = new Xcls_MenuItem8( _this );
686             child_0.ref();
687             this.el.append (  child_0.el  );
688             var child_1 = new Xcls_MenuItem9( _this );
689             child_1.ref();
690             this.el.append (  child_1.el  );
691             var child_2 = new Xcls_MenuItem10( _this );
692             child_2.ref();
693             this.el.append (  child_2.el  );
694             var child_3 = new Xcls_MenuItem11( _this );
695             child_3.ref();
696             this.el.append (  child_3.el  );
697             var child_4 = new Xcls_SeparatorMenuItem12( _this );
698             child_4.ref();
699             this.el.add (  child_4.el  );
700             var child_5 = new Xcls_MenuItem13( _this );
701             child_5.ref();
702             this.el.append (  child_5.el  );
703             var child_6 = new Xcls_MenuItem14( _this );
704             child_6.ref();
705             this.el.append (  child_6.el  );
706             var child_7 = new Xcls_MenuItem15( _this );
707             child_7.ref();
708             this.el.append (  child_7.el  );
709             var child_8 = new Xcls_SeparatorMenuItem16( _this );
710             child_8.ref();
711             this.el.add (  child_8.el  );
712             var child_9 = new Xcls_MenuItem17( _this );
713             child_9.ref();
714             this.el.append (  child_9.el  );
715             var child_10 = new Xcls_MenuItem18( _this );
716             child_10.ref();
717             this.el.append (  child_10.el  );
718             var child_11 = new Xcls_MenuItem19( _this );
719             child_11.ref();
720             this.el.append (  child_11.el  );
721             var child_12 = new Xcls_SeparatorMenuItem20( _this );
722             child_12.ref();
723             this.el.add (  child_12.el  );
724             var child_13 = new Xcls_MenuItem21( _this );
725             child_13.ref();
726             this.el.append (  child_13.el  );
727         }
728
729         // user defined functions 
730     }
731     public class Xcls_MenuItem8 : Object 
732     {
733         public Gtk.MenuItem el;
734         private Xcls_LeftProps  _this;
735
736
737             // my vars (def)
738
739         // ctor 
740         public Xcls_MenuItem8(Xcls_LeftProps _owner )
741         {
742             _this = _owner;
743             this.el = new Gtk.MenuItem();
744
745             // my vars (dec)
746
747             // set gobject values
748             this.el.tooltip_markup = "Using _this.{ID} will map to this element";
749             this.el.label = "id: _this.{ID} (Vala)";
750
751             // listeners 
752             this.el.activate.connect( ()  => {
753                 _this.addProp( "prop", "id", "", "");
754             });
755         }
756
757         // user defined functions 
758     }
759     public class Xcls_MenuItem9 : Object 
760     {
761         public Gtk.MenuItem el;
762         private Xcls_LeftProps  _this;
763
764
765             // my vars (def)
766
767         // ctor 
768         public Xcls_MenuItem9(Xcls_LeftProps _owner )
769         {
770             _this = _owner;
771             this.el = new Gtk.MenuItem();
772
773             // my vars (dec)
774
775             // set gobject values
776             this.el.tooltip_markup = "how to pack this element onto parent, (method, 2nd arg, 3rd arg) .. the 1st argument is filled by the element";
777             this.el.label = "pack: Pack method (Vala)";
778
779             // listeners 
780             this.el.activate.connect( ( ) => {
781             
782                 _this.addProp( "prop", "pack","add", "*");
783             });
784         }
785
786         // user defined functions 
787     }
788     public class Xcls_MenuItem10 : Object 
789     {
790         public Gtk.MenuItem el;
791         private Xcls_LeftProps  _this;
792
793
794             // my vars (def)
795
796         // ctor 
797         public Xcls_MenuItem10(Xcls_LeftProps _owner )
798         {
799             _this = _owner;
800             this.el = new Gtk.MenuItem();
801
802             // my vars (dec)
803
804             // set gobject values
805             this.el.tooltip_markup = "eg. \n\nnew Clutter.Image.from_file(.....)";
806             this.el.label = "ctor: Alterative to default contructor";
807
808             // listeners 
809             this.el.activate.connect( ( ) => {
810             
811                 _this.addProp( "prop", "ctor","", "*");
812             });
813         }
814
815         // user defined functions 
816     }
817     public class Xcls_MenuItem11 : Object 
818     {
819         public Gtk.MenuItem el;
820         private Xcls_LeftProps  _this;
821
822
823             // my vars (def)
824
825         // ctor 
826         public Xcls_MenuItem11(Xcls_LeftProps _owner )
827         {
828             _this = _owner;
829             this.el = new Gtk.MenuItem();
830
831             // my vars (dec)
832
833             // set gobject values
834             this.el.tooltip_markup = "This code is called after the ctor";
835             this.el.label = "init: initialziation code (vala)";
836
837             // listeners 
838             this.el.activate.connect( ( ) => {
839             
840                 _this.addProp( "prop",  "init", "{\n\n}\n", "*" );
841             });
842         }
843
844         // user defined functions 
845     }
846     public class Xcls_SeparatorMenuItem12 : Object 
847     {
848         public Gtk.SeparatorMenuItem el;
849         private Xcls_LeftProps  _this;
850
851
852             // my vars (def)
853
854         // ctor 
855         public Xcls_SeparatorMenuItem12(Xcls_LeftProps _owner )
856         {
857             _this = _owner;
858             this.el = new Gtk.SeparatorMenuItem();
859
860             // my vars (dec)
861
862             // set gobject values
863         }
864
865         // user defined functions 
866     }
867     public class Xcls_MenuItem13 : Object 
868     {
869         public Gtk.MenuItem el;
870         private Xcls_LeftProps  _this;
871
872
873             // my vars (def)
874
875         // ctor 
876         public Xcls_MenuItem13(Xcls_LeftProps _owner )
877         {
878             _this = _owner;
879             this.el = new Gtk.MenuItem();
880
881             // my vars (dec)
882
883             // set gobject values
884             this.el.tooltip_markup = "Add a user defined string property";
885             this.el.label = "String";
886
887             // listeners 
888             this.el.activate.connect( (self) => {
889             
890                 _this.addProp( "prop", "XXXX", "","string");
891             
892             });
893         }
894
895         // user defined functions 
896     }
897     public class Xcls_MenuItem14 : Object 
898     {
899         public Gtk.MenuItem el;
900         private Xcls_LeftProps  _this;
901
902
903             // my vars (def)
904
905         // ctor 
906         public Xcls_MenuItem14(Xcls_LeftProps _owner )
907         {
908             _this = _owner;
909             this.el = new Gtk.MenuItem();
910
911             // my vars (dec)
912
913             // set gobject values
914             this.el.tooltip_markup = "Add a user defined number property";
915             this.el.label = "Number";
916
917             // listeners 
918             this.el.activate.connect( ( ) =>{
919             
920                 _this.addProp("prop",  "XXX", "0", "int");
921             });
922         }
923
924         // user defined functions 
925     }
926     public class Xcls_MenuItem15 : Object 
927     {
928         public Gtk.MenuItem el;
929         private Xcls_LeftProps  _this;
930
931
932             // my vars (def)
933
934         // ctor 
935         public Xcls_MenuItem15(Xcls_LeftProps _owner )
936         {
937             _this = _owner;
938             this.el = new Gtk.MenuItem();
939
940             // my vars (dec)
941
942             // set gobject values
943             this.el.tooltip_markup = "Add a user defined boolean property";
944             this.el.label = "Boolean";
945
946             // listeners 
947             this.el.activate.connect( ( ) =>{
948             
949                 _this.addProp( "prop", "XXX", "true", "bool");
950             });
951         }
952
953         // user defined functions 
954     }
955     public class Xcls_SeparatorMenuItem16 : Object 
956     {
957         public Gtk.SeparatorMenuItem el;
958         private Xcls_LeftProps  _this;
959
960
961             // my vars (def)
962
963         // ctor 
964         public Xcls_SeparatorMenuItem16(Xcls_LeftProps _owner )
965         {
966             _this = _owner;
967             this.el = new Gtk.SeparatorMenuItem();
968
969             // my vars (dec)
970
971             // set gobject values
972         }
973
974         // user defined functions 
975     }
976     public class Xcls_MenuItem17 : Object 
977     {
978         public Gtk.MenuItem el;
979         private Xcls_LeftProps  _this;
980
981
982             // my vars (def)
983
984         // ctor 
985         public Xcls_MenuItem17(Xcls_LeftProps _owner )
986         {
987             _this = _owner;
988             this.el = new Gtk.MenuItem();
989
990             // my vars (dec)
991
992             // set gobject values
993             this.el.tooltip_markup = "Add a user function boolean property";
994             this.el.label = "Javascript Function";
995
996             // listeners 
997             this.el.activate.connect( ( ) =>{
998             
999                 _this.addProp("prop",  "XXXX", "function() { }", "| function");
1000             });
1001         }
1002
1003         // user defined functions 
1004     }
1005     public class Xcls_MenuItem18 : Object 
1006     {
1007         public Gtk.MenuItem el;
1008         private Xcls_LeftProps  _this;
1009
1010
1011             // my vars (def)
1012
1013         // ctor 
1014         public Xcls_MenuItem18(Xcls_LeftProps _owner )
1015         {
1016             _this = _owner;
1017             this.el = new Gtk.MenuItem();
1018
1019             // my vars (dec)
1020
1021             // set gobject values
1022             this.el.tooltip_markup = "Add a user function boolean property";
1023             this.el.label = "Vala Method";
1024
1025             // listeners 
1026             this.el.activate.connect( ( ) =>{
1027             
1028                 _this.addProp( "prop", "XXXX", "() {\n\n}\n", "| return_type");
1029             });
1030         }
1031
1032         // user defined functions 
1033     }
1034     public class Xcls_MenuItem19 : Object 
1035     {
1036         public Gtk.MenuItem el;
1037         private Xcls_LeftProps  _this;
1038
1039
1040             // my vars (def)
1041
1042         // ctor 
1043         public Xcls_MenuItem19(Xcls_LeftProps _owner )
1044         {
1045             _this = _owner;
1046             this.el = new Gtk.MenuItem();
1047
1048             // my vars (dec)
1049
1050             // set gobject values
1051             this.el.tooltip_markup = "Add a vala signal";
1052             this.el.label = "Vala Signal";
1053
1054             // listeners 
1055             this.el.activate.connect( ( ) =>{
1056             
1057                 _this.addProp( "prop", "XXXX", "()", "@ void");
1058             });
1059         }
1060
1061         // user defined functions 
1062     }
1063     public class Xcls_SeparatorMenuItem20 : Object 
1064     {
1065         public Gtk.SeparatorMenuItem el;
1066         private Xcls_LeftProps  _this;
1067
1068
1069             // my vars (def)
1070
1071         // ctor 
1072         public Xcls_SeparatorMenuItem20(Xcls_LeftProps _owner )
1073         {
1074             _this = _owner;
1075             this.el = new Gtk.SeparatorMenuItem();
1076
1077             // my vars (dec)
1078
1079             // set gobject values
1080         }
1081
1082         // user defined functions 
1083     }
1084     public class Xcls_MenuItem21 : Object 
1085     {
1086         public Gtk.MenuItem el;
1087         private Xcls_LeftProps  _this;
1088
1089
1090             // my vars (def)
1091
1092         // ctor 
1093         public Xcls_MenuItem21(Xcls_LeftProps _owner )
1094         {
1095             _this = _owner;
1096             this.el = new Gtk.MenuItem();
1097
1098             // my vars (dec)
1099
1100             // set gobject values
1101             this.el.tooltip_markup = "Add a user function boolean property";
1102             this.el.label = "Flexy - Foreach";
1103
1104             // listeners 
1105             this.el.activate.connect( ( ) =>{
1106             
1107                 _this.addProp("prop",  "XXXX", "function() { }", "| function");
1108             });
1109         }
1110
1111         // user defined functions 
1112     }
1113     public class Xcls_EditProps : Object 
1114     {
1115         public Gtk.ScrolledWindow el;
1116         private Xcls_LeftProps  _this;
1117
1118
1119             // my vars (def)
1120         public bool editing;
1121
1122         // ctor 
1123         public Xcls_EditProps(Xcls_LeftProps _owner )
1124         {
1125             _this = _owner;
1126             _this.EditProps = this;
1127             this.el = new Gtk.ScrolledWindow( null, null );
1128
1129             // my vars (dec)
1130             this.editing = false;
1131
1132             // set gobject values
1133             this.el.shadow_type = Gtk.ShadowType.IN;
1134             var child_0 = new Xcls_view( _this );
1135             child_0.ref();
1136             this.el.add (  child_0.el  );
1137
1138             // init method 
1139
1140             {
1141               
1142                this.el.set_policy (Gtk.PolicyType.AUTOMATIC, Gtk.PolicyType.AUTOMATIC);
1143             }
1144         }
1145
1146         // user defined functions 
1147     }
1148     public class Xcls_view : Object 
1149     {
1150         public Gtk.TreeView el;
1151         private Xcls_LeftProps  _this;
1152
1153
1154             // my vars (def)
1155
1156         // ctor 
1157         public Xcls_view(Xcls_LeftProps _owner )
1158         {
1159             _this = _owner;
1160             _this.view = this;
1161             this.el = new Gtk.TreeView();
1162
1163             // my vars (dec)
1164
1165             // set gobject values
1166             this.el.tooltip_column = 5;
1167             this.el.enable_tree_lines = true;
1168             this.el.headers_visible = true;
1169             var child_0 = new Xcls_model( _this );
1170             child_0.ref();
1171             this.el.set_model (  child_0.el  );
1172             var child_1 = new Xcls_keycol( _this );
1173             child_1.ref();
1174             this.el.append_column (  child_1.el  );
1175             var child_2 = new Xcls_valcol( _this );
1176             child_2.ref();
1177             this.el.append_column (  child_2.el  );
1178             var child_3 = new Xcls_ContextMenu( _this );
1179             child_3.ref();
1180
1181             // init method 
1182
1183             {
1184                 var selection = this.el.get_selection();
1185                 selection.set_mode( Gtk.SelectionMode.SINGLE);
1186             
1187             
1188                 var description = new Pango.FontDescription();
1189                 description.set_size(8000);
1190                 this.el.modify_font(description);
1191             }
1192
1193             // listeners 
1194             this.el.button_press_event.connect( ( ev)  => {
1195              
1196                 Gtk.TreeViewColumn col;
1197                 int cell_x;
1198                 int cell_y;
1199                 Gtk.TreePath path;
1200                 if (!this.el.get_path_at_pos((int)ev.x, (int) ev.y, out path, out col, out cell_x, out cell_y )) {
1201                     print("nothing selected on click");
1202                     GLib.Timeout.add_full(GLib.Priority.DEFAULT,10 , () => {
1203                         this.el.get_selection().unselect_all();
1204             
1205                         return false;
1206                     });
1207                      _this.before_edit();
1208                     return false; //not on a element.
1209                 }
1210                 
1211                 
1212                  // right click.
1213                  if (ev.type == Gdk.EventType.2BUTTON_PRESS  && ev.button == 1 && col.title == "Name") {    
1214                     // show popup!.   
1215                     
1216              
1217                      _this.before_edit();
1218                      
1219                      _this.keyrender.el.stop_editing(false);
1220                      _this.keyrender.el.editable  =false;
1221                 
1222                      _this.valrender.el.stop_editing(false);
1223                      _this.valrender.el.editable  =false;
1224                        
1225                       _this.startEditingKey(path); 
1226                      
1227                     return false;
1228                 }
1229                 
1230                 
1231                 
1232                 
1233                  // right click.
1234                  if (ev.type == Gdk.EventType.BUTTON_PRESS  && ev.button == 3) {    
1235                     // show popup!.   
1236                     //if (col.title == "Value") {
1237                      //     _this.before_edit();
1238                      //    return false;
1239                      //}
1240             
1241                     var p = _this.ContextMenu;
1242             
1243                     p.el.set_screen(Gdk.Screen.get_default());
1244                     p.el.show_all();
1245                     p.el.popup(null, null, null,  ev.button, ev.time);
1246                     //Seed.print("click:" + res.column.title);
1247                     // select the 
1248                     GLib.Timeout.add_full(GLib.Priority.DEFAULT,10 , () => {
1249               
1250                         this.el.get_selection().select_path(path);
1251                         return false;
1252                     });
1253                      _this.before_edit();
1254                     return false;
1255                 }
1256                 
1257                  
1258                 if (col.title != "Value") {
1259                     print("col title != Value");
1260                     
1261                     GLib.Timeout.add_full(GLib.Priority.DEFAULT,10 , () => {
1262                         this.el.get_selection().select_path(path);
1263                         return false;
1264                     });
1265                     
1266                     _this.before_edit();
1267                       //  XObject.error("column is not value?");
1268                     return false; // ignore.. - key click.. ??? should we do this??
1269                 }
1270                 
1271                 
1272                 // if the cell can be edited with a pulldown
1273                 // then we should return true... - and let the start_editing handle it?
1274                 
1275                 
1276                 
1277                 
1278                 
1279                   
1280                //             _this.before_edit(); <<< we really need to stop the other editor..
1281                  _this.keyrender.el.stop_editing(false);
1282                 _this.keyrender.el.editable  =false;
1283                 
1284                        
1285                 return _this.startEditingValue(path); // assumes selected row..
1286                     
1287                
1288             
1289                           
1290                
1291             });
1292         }
1293
1294         // user defined functions 
1295     }
1296     public class Xcls_model : Object 
1297     {
1298         public Gtk.TreeStore el;
1299         private Xcls_LeftProps  _this;
1300
1301
1302             // my vars (def)
1303
1304         // ctor 
1305         public Xcls_model(Xcls_LeftProps _owner )
1306         {
1307             _this = _owner;
1308             _this.model = this;
1309             this.el = new Gtk.TreeStore( 7,      typeof(string),  // 0 key type
1310      typeof(string),  // 1 key
1311      typeof(string),  // 2 key (display)
1312      typeof(string),  // 3 value
1313      typeof(string),   // 4 value (display)
1314      typeof(string),   // 5 both (tooltip)     
1315      typeof(string)   // 6 key (for sorting)
1316  );
1317
1318             // my vars (dec)
1319
1320             // set gobject values
1321         }
1322
1323         // user defined functions 
1324     }
1325     public class Xcls_keycol : Object 
1326     {
1327         public Gtk.TreeViewColumn el;
1328         private Xcls_LeftProps  _this;
1329
1330
1331             // my vars (def)
1332
1333         // ctor 
1334         public Xcls_keycol(Xcls_LeftProps _owner )
1335         {
1336             _this = _owner;
1337             _this.keycol = this;
1338             this.el = new Gtk.TreeViewColumn();
1339
1340             // my vars (dec)
1341
1342             // set gobject values
1343             this.el.title = "Name";
1344             this.el.resizable = true;
1345             var child_0 = new Xcls_keyrender( _this );
1346             child_0.ref();
1347             this.el.pack_start (  child_0.el , false );
1348
1349             // init method 
1350
1351             this.el.add_attribute(_this.keyrender.el , "markup", 2 );
1352              this.el.add_attribute(_this.keyrender.el , "text", 1 );
1353         }
1354
1355         // user defined functions 
1356     }
1357     public class Xcls_keyrender : Object 
1358     {
1359         public Gtk.CellRendererText el;
1360         private Xcls_LeftProps  _this;
1361
1362
1363             // my vars (def)
1364
1365         // ctor 
1366         public Xcls_keyrender(Xcls_LeftProps _owner )
1367         {
1368             _this = _owner;
1369             _this.keyrender = this;
1370             this.el = new Gtk.CellRendererText();
1371
1372             // my vars (dec)
1373
1374             // set gobject values
1375
1376             // listeners 
1377             this.el.editing_started.connect( (  editable, path) => {
1378             
1379                  Gtk.TreeIter  iter;
1380                 _this.model.el.get_iter(out iter, new Gtk.TreePath.from_string(path));
1381                 GLib.Value gval;
1382                               
1383             
1384             
1385                  //   this.get('/LeftPanel.model').activePath  = path;
1386                 _this.model.el.get_value(iter,1, out gval);
1387                     var val = (string)gval;
1388                              
1389                     ((Gtk.Entry)editable).set_text(val);                 
1390             });
1391             this.el.edited.connect( (path, newtext) => {
1392                     print("Keyrender  - signal:edited\n");
1393                 
1394                 this.el.editable = false;
1395               
1396              
1397             
1398                     Gtk.TreeIter  iter;
1399                     _this.model.el.get_iter(out iter, new Gtk.TreePath.from_string(path));
1400                     GLib.Value gval;
1401                     
1402                      _this.model.el.get_value(iter,1, out gval);
1403                     var oldval = (string)gval;
1404                     
1405                      _this.model.el.get_value(iter,0, out gval);
1406                     var ktype = (string)gval;
1407                    
1408                     _this.model.el.set_value(iter, 1, newtext);
1409                     
1410                     if (oldval == newtext) {
1411                         return;
1412                     }
1413                     
1414                     
1415                     print("ktype: %s\n",ktype);
1416                     switch(ktype) {
1417                         case "listener":
1418                             var ov = _this.node.listeners.get(oldval);
1419                             _this.node.listeners.set(newtext, ov);
1420                             _this.node.listeners.remove(oldval);
1421                             
1422                             _this.updateIter(iter,  ktype, newtext, ov);
1423                             
1424                             break;
1425                         case "props":
1426                             var ov = _this.node.props.get(oldval);
1427                             _this.node.props.set(newtext, ov);
1428                             _this.node.props.remove(oldval);
1429                             _this.updateIter(iter,  ktype, newtext, ov);
1430                             break;
1431                      }
1432                      _this.changed();
1433                       
1434             });
1435         }
1436
1437         // user defined functions 
1438     }
1439     public class Xcls_valcol : Object 
1440     {
1441         public Gtk.TreeViewColumn el;
1442         private Xcls_LeftProps  _this;
1443
1444
1445             // my vars (def)
1446
1447         // ctor 
1448         public Xcls_valcol(Xcls_LeftProps _owner )
1449         {
1450             _this = _owner;
1451             _this.valcol = this;
1452             this.el = new Gtk.TreeViewColumn();
1453
1454             // my vars (dec)
1455
1456             // set gobject values
1457             this.el.title = "Value";
1458             this.el.resizable = true;
1459             var child_0 = new Xcls_valrender( _this );
1460             child_0.ref();
1461             this.el.pack_start (  child_0.el , true );
1462
1463             // init method 
1464
1465             {
1466                 
1467                 //     typeof(string),  // 0 key type
1468                 // typeof(string),  // 1 key
1469                 // typeof(string),  // 2 key (display)
1470                 // typeof(string),  // 3 value
1471                 // typeof(string)   // 4 value (display)
1472             
1473                 
1474                 this.el.add_attribute(_this.valrender.el , "text", 4 );
1475                 //this.el.add_attribute(_this.valrender.el , "sensitive", 4 );
1476                 //this.el.add_attribute(this.items[0].el , 'editable', 3 );
1477                       // this.el.set_cell_data_func(cell, age_cell_data_func, NULL, NULL);
1478             
1479              // this.get('/LeftPanel').editableColumn= this;
1480             }
1481         }
1482
1483         // user defined functions 
1484     }
1485     public class Xcls_valrender : Object 
1486     {
1487         public Gtk.CellRendererCombo el;
1488         private Xcls_LeftProps  _this;
1489
1490
1491             // my vars (def)
1492
1493         // ctor 
1494         public Xcls_valrender(Xcls_LeftProps _owner )
1495         {
1496             _this = _owner;
1497             _this.valrender = this;
1498             this.el = new Gtk.CellRendererCombo();
1499
1500             // my vars (dec)
1501
1502             // set gobject values
1503             this.el.editable = false;
1504             this.el.text_column = 0;
1505             this.el.has_entry = true;
1506             var child_0 = new Xcls_valrendermodel( _this );
1507             child_0.ref();
1508             this.el.model = child_0.el;
1509
1510             // listeners 
1511             this.el.editing_started.connect( ( editable, path) => {
1512                 //_this.editing = true;
1513                 print("editing started called\n");
1514                 if (!_this.allow_edit) {
1515                    
1516                      print("val - editing_Started\n");
1517                     this.el.editable = false; // make sure it's not editor...
1518                
1519                      
1520                     return;
1521                 }
1522                  _this.allow_edit =false;
1523                 
1524                
1525                  if (       this.el.has_entry ) {
1526                
1527                      Gtk.TreeIter  iter;
1528                     _this.model.el.get_iter(out iter, new Gtk.TreePath.from_string(path));
1529                     GLib.Value gval;
1530                                   
1531             
1532                   
1533                      //   this.get('/LeftPanel.model').activePath  = path;
1534                    _this.model.el.get_value(iter,3, out gval);
1535                 
1536             
1537                     var val = (string)gval;
1538                     var combo =        (Gtk.ComboBox)editable;
1539             
1540                    var entry =  (Gtk.Entry) combo.get_child();        
1541                 entry.set_text(val);
1542                 }
1543                
1544             });
1545             this.el.edited.connect( (path, newtext) => {
1546                 print("Valrender  - signal:edited\n");
1547               
1548                     this.el.editable = false;
1549             /*  
1550              m.set(iter, 
1551                             0, "listener",
1552                             1, miter.get_key(),
1553                             2, "<b>" + miter.get_key() + "</b>",
1554                             3, miter.get_value(),
1555                             4, display_value(short);
1556                         ); 
1557             
1558               */      
1559             
1560                     Gtk.TreeIter  iter;
1561                     _this.model.el.get_iter(out iter, new Gtk.TreePath.from_string(path));
1562                     GLib.Value gval;
1563                     
1564                      _this.model.el.get_value(iter,0, out gval);
1565                     var ktype = (string)gval;
1566                     
1567                     
1568                      _this.model.el.get_value(iter,3, out gval);
1569                     var oldval = (string)gval;
1570                     
1571                      _this.model.el.get_value(iter,1, out gval);
1572                     var key = (string)gval;
1573                     
1574                      
1575                     
1576                     switch(ktype) {
1577                         case "listener":
1578                             _this.node.listeners.set(key, newtext);
1579                             _this.updateIter(iter,ktype,key,newtext);
1580                             break;
1581                         case "props":
1582                             _this.node.props.set(key,newtext);
1583                             _this.updateIter(iter,ktype, key,newtext);                
1584                             break;
1585                      }
1586             //         _this.load(_this.file,_this.node);
1587                      _this.changed();
1588                       
1589             });
1590         }
1591
1592         // user defined functions 
1593         public              void setOptions (string[] ar) {
1594               var m = _this.valrendermodel.el;
1595                 m.clear();
1596              Gtk.TreeIter iret;
1597             for (var i =0; i < ar.length; i++) {
1598                     m.append(out iret);
1599                     m.set_value(iret, 0, ar[i]);
1600             }
1601         
1602         }
1603     }
1604     public class Xcls_valrendermodel : Object 
1605     {
1606         public Gtk.ListStore el;
1607         private Xcls_LeftProps  _this;
1608
1609
1610             // my vars (def)
1611
1612         // ctor 
1613         public Xcls_valrendermodel(Xcls_LeftProps _owner )
1614         {
1615             _this = _owner;
1616             _this.valrendermodel = this;
1617             this.el = new Gtk.ListStore( 1, typeof(string) );
1618
1619             // my vars (dec)
1620
1621             // set gobject values
1622         }
1623
1624         // user defined functions 
1625     }
1626     public class Xcls_ContextMenu : Object 
1627     {
1628         public Gtk.Menu el;
1629         private Xcls_LeftProps  _this;
1630
1631
1632             // my vars (def)
1633
1634         // ctor 
1635         public Xcls_ContextMenu(Xcls_LeftProps _owner )
1636         {
1637             _this = _owner;
1638             _this.ContextMenu = this;
1639             this.el = new Gtk.Menu();
1640
1641             // my vars (dec)
1642
1643             // set gobject values
1644             var child_0 = new Xcls_MenuItem31( _this );
1645             child_0.ref();
1646             this.el.append (  child_0.el  );
1647             var child_1 = new Xcls_SeparatorMenuItem32( _this );
1648             child_1.ref();
1649             this.el.append (  child_1.el  );
1650             var child_2 = new Xcls_MenuItem33( _this );
1651             child_2.ref();
1652             this.el.append (  child_2.el  );
1653         }
1654
1655         // user defined functions 
1656     }
1657     public class Xcls_MenuItem31 : Object 
1658     {
1659         public Gtk.MenuItem el;
1660         private Xcls_LeftProps  _this;
1661
1662
1663             // my vars (def)
1664
1665         // ctor 
1666         public Xcls_MenuItem31(Xcls_LeftProps _owner )
1667         {
1668             _this = _owner;
1669             this.el = new Gtk.MenuItem();
1670
1671             // my vars (dec)
1672
1673             // set gobject values
1674             this.el.label = "Edit";
1675
1676             // listeners 
1677             this.el.activate.connect( ( )  =>{
1678               
1679                 var s = _this.view.el.get_selection();
1680                 Gtk.TreeIter iter;
1681                 Gtk.TreeModel model;
1682                 s.get_selected (out  model, out  iter);
1683                 _this.startEditingKey(model.get_path(iter));
1684             });
1685         }
1686
1687         // user defined functions 
1688     }
1689     public class Xcls_SeparatorMenuItem32 : Object 
1690     {
1691         public Gtk.SeparatorMenuItem el;
1692         private Xcls_LeftProps  _this;
1693
1694
1695             // my vars (def)
1696
1697         // ctor 
1698         public Xcls_SeparatorMenuItem32(Xcls_LeftProps _owner )
1699         {
1700             _this = _owner;
1701             this.el = new Gtk.SeparatorMenuItem();
1702
1703             // my vars (dec)
1704
1705             // set gobject values
1706         }
1707
1708         // user defined functions 
1709     }
1710     public class Xcls_MenuItem33 : Object 
1711     {
1712         public Gtk.MenuItem el;
1713         private Xcls_LeftProps  _this;
1714
1715
1716             // my vars (def)
1717
1718         // ctor 
1719         public Xcls_MenuItem33(Xcls_LeftProps _owner )
1720         {
1721             _this = _owner;
1722             this.el = new Gtk.MenuItem();
1723
1724             // my vars (dec)
1725
1726             // set gobject values
1727             this.el.label = "Delete";
1728
1729             // listeners 
1730             this.el.activate.connect( ( )  =>{
1731                 _this.deleteSelected();
1732             });
1733         }
1734
1735         // user defined functions 
1736     }
1737 }