Attribute changed old-javascript
[app.Builder.js] / old-javascript / 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         }
719
720         // user defined functions 
721     }
722     public class Xcls_MenuItem8 : Object 
723     {
724         public Gtk.MenuItem el;
725         private Xcls_LeftProps  _this;
726
727
728             // my vars (def)
729
730         // ctor 
731         public Xcls_MenuItem8(Xcls_LeftProps _owner )
732         {
733             _this = _owner;
734             this.el = new Gtk.MenuItem();
735
736             // my vars (dec)
737
738             // set gobject values
739             this.el.tooltip_markup = "Using _this.{ID} will map to this element";
740             this.el.label = "id: _this.{ID} (Vala)";
741
742             // listeners 
743             this.el.activate.connect( ()  => {
744                 _this.addProp( "prop", "id", "", "");
745             });
746         }
747
748         // user defined functions 
749     }
750     public class Xcls_MenuItem9 : Object 
751     {
752         public Gtk.MenuItem el;
753         private Xcls_LeftProps  _this;
754
755
756             // my vars (def)
757
758         // ctor 
759         public Xcls_MenuItem9(Xcls_LeftProps _owner )
760         {
761             _this = _owner;
762             this.el = new Gtk.MenuItem();
763
764             // my vars (dec)
765
766             // set gobject values
767             this.el.tooltip_markup = "how to pack this element onto parent, (method, 2nd arg, 3rd arg) .. the 1st argument is filled by the element";
768             this.el.label = "pack: Pack method (Vala)";
769
770             // listeners 
771             this.el.activate.connect( ( ) => {
772             
773                 _this.addProp( "prop", "pack","add", "*");
774             });
775         }
776
777         // user defined functions 
778     }
779     public class Xcls_MenuItem10 : Object 
780     {
781         public Gtk.MenuItem el;
782         private Xcls_LeftProps  _this;
783
784
785             // my vars (def)
786
787         // ctor 
788         public Xcls_MenuItem10(Xcls_LeftProps _owner )
789         {
790             _this = _owner;
791             this.el = new Gtk.MenuItem();
792
793             // my vars (dec)
794
795             // set gobject values
796             this.el.tooltip_markup = "eg. \n\nnew Clutter.Image.from_file(.....)";
797             this.el.label = "ctor: Alterative to default contructor";
798
799             // listeners 
800             this.el.activate.connect( ( ) => {
801             
802                 _this.addProp( "prop", "ctor","", "*");
803             });
804         }
805
806         // user defined functions 
807     }
808     public class Xcls_MenuItem11 : Object 
809     {
810         public Gtk.MenuItem el;
811         private Xcls_LeftProps  _this;
812
813
814             // my vars (def)
815
816         // ctor 
817         public Xcls_MenuItem11(Xcls_LeftProps _owner )
818         {
819             _this = _owner;
820             this.el = new Gtk.MenuItem();
821
822             // my vars (dec)
823
824             // set gobject values
825             this.el.tooltip_markup = "This code is called after the ctor";
826             this.el.label = "init: initialziation code (vala)";
827
828             // listeners 
829             this.el.activate.connect( ( ) => {
830             
831                 _this.addProp( "prop",  "init", "{\n\n}\n", "*" );
832             });
833         }
834
835         // user defined functions 
836     }
837     public class Xcls_SeparatorMenuItem12 : Object 
838     {
839         public Gtk.SeparatorMenuItem el;
840         private Xcls_LeftProps  _this;
841
842
843             // my vars (def)
844
845         // ctor 
846         public Xcls_SeparatorMenuItem12(Xcls_LeftProps _owner )
847         {
848             _this = _owner;
849             this.el = new Gtk.SeparatorMenuItem();
850
851             // my vars (dec)
852
853             // set gobject values
854         }
855
856         // user defined functions 
857     }
858     public class Xcls_MenuItem13 : Object 
859     {
860         public Gtk.MenuItem el;
861         private Xcls_LeftProps  _this;
862
863
864             // my vars (def)
865
866         // ctor 
867         public Xcls_MenuItem13(Xcls_LeftProps _owner )
868         {
869             _this = _owner;
870             this.el = new Gtk.MenuItem();
871
872             // my vars (dec)
873
874             // set gobject values
875             this.el.tooltip_markup = "Add a user defined string property";
876             this.el.label = "String";
877
878             // listeners 
879             this.el.activate.connect( (self) => {
880             
881                 _this.addProp( "prop", "XXXX", "","string");
882             
883             });
884         }
885
886         // user defined functions 
887     }
888     public class Xcls_MenuItem14 : Object 
889     {
890         public Gtk.MenuItem el;
891         private Xcls_LeftProps  _this;
892
893
894             // my vars (def)
895
896         // ctor 
897         public Xcls_MenuItem14(Xcls_LeftProps _owner )
898         {
899             _this = _owner;
900             this.el = new Gtk.MenuItem();
901
902             // my vars (dec)
903
904             // set gobject values
905             this.el.tooltip_markup = "Add a user defined number property";
906             this.el.label = "Number";
907
908             // listeners 
909             this.el.activate.connect( ( ) =>{
910             
911                 _this.addProp("prop",  "XXX", "0", "int");
912             });
913         }
914
915         // user defined functions 
916     }
917     public class Xcls_MenuItem15 : Object 
918     {
919         public Gtk.MenuItem el;
920         private Xcls_LeftProps  _this;
921
922
923             // my vars (def)
924
925         // ctor 
926         public Xcls_MenuItem15(Xcls_LeftProps _owner )
927         {
928             _this = _owner;
929             this.el = new Gtk.MenuItem();
930
931             // my vars (dec)
932
933             // set gobject values
934             this.el.tooltip_markup = "Add a user defined boolean property";
935             this.el.label = "Boolean";
936
937             // listeners 
938             this.el.activate.connect( ( ) =>{
939             
940                 _this.addProp( "prop", "XXX", "true", "bool");
941             });
942         }
943
944         // user defined functions 
945     }
946     public class Xcls_SeparatorMenuItem16 : Object 
947     {
948         public Gtk.SeparatorMenuItem el;
949         private Xcls_LeftProps  _this;
950
951
952             // my vars (def)
953
954         // ctor 
955         public Xcls_SeparatorMenuItem16(Xcls_LeftProps _owner )
956         {
957             _this = _owner;
958             this.el = new Gtk.SeparatorMenuItem();
959
960             // my vars (dec)
961
962             // set gobject values
963         }
964
965         // user defined functions 
966     }
967     public class Xcls_MenuItem17 : Object 
968     {
969         public Gtk.MenuItem el;
970         private Xcls_LeftProps  _this;
971
972
973             // my vars (def)
974
975         // ctor 
976         public Xcls_MenuItem17(Xcls_LeftProps _owner )
977         {
978             _this = _owner;
979             this.el = new Gtk.MenuItem();
980
981             // my vars (dec)
982
983             // set gobject values
984             this.el.tooltip_markup = "Add a user function boolean property";
985             this.el.label = "Javascript Function";
986
987             // listeners 
988             this.el.activate.connect( ( ) =>{
989             
990                 _this.addProp("prop",  "XXXX", "function() { }", "| function");
991             });
992         }
993
994         // user defined functions 
995     }
996     public class Xcls_MenuItem18 : Object 
997     {
998         public Gtk.MenuItem el;
999         private Xcls_LeftProps  _this;
1000
1001
1002             // my vars (def)
1003
1004         // ctor 
1005         public Xcls_MenuItem18(Xcls_LeftProps _owner )
1006         {
1007             _this = _owner;
1008             this.el = new Gtk.MenuItem();
1009
1010             // my vars (dec)
1011
1012             // set gobject values
1013             this.el.tooltip_markup = "Add a user function boolean property";
1014             this.el.label = "Vala Method";
1015
1016             // listeners 
1017             this.el.activate.connect( ( ) =>{
1018             
1019                 _this.addProp( "prop", "XXXX", "() {\n\n}\n", "| return_type");
1020             });
1021         }
1022
1023         // user defined functions 
1024     }
1025     public class Xcls_EditProps : Object 
1026     {
1027         public Gtk.ScrolledWindow el;
1028         private Xcls_LeftProps  _this;
1029
1030
1031             // my vars (def)
1032         public bool editing;
1033
1034         // ctor 
1035         public Xcls_EditProps(Xcls_LeftProps _owner )
1036         {
1037             _this = _owner;
1038             _this.EditProps = this;
1039             this.el = new Gtk.ScrolledWindow( null, null );
1040
1041             // my vars (dec)
1042             this.editing = false;
1043
1044             // set gobject values
1045             this.el.shadow_type = Gtk.ShadowType.IN;
1046             var child_0 = new Xcls_view( _this );
1047             child_0.ref();
1048             this.el.add (  child_0.el  );
1049
1050             // init method 
1051
1052             {
1053               
1054                this.el.set_policy (Gtk.PolicyType.AUTOMATIC, Gtk.PolicyType.AUTOMATIC);
1055             }        }
1056
1057         // user defined functions 
1058     }
1059     public class Xcls_view : Object 
1060     {
1061         public Gtk.TreeView el;
1062         private Xcls_LeftProps  _this;
1063
1064
1065             // my vars (def)
1066
1067         // ctor 
1068         public Xcls_view(Xcls_LeftProps _owner )
1069         {
1070             _this = _owner;
1071             _this.view = this;
1072             this.el = new Gtk.TreeView();
1073
1074             // my vars (dec)
1075
1076             // set gobject values
1077             this.el.tooltip_column = 5;
1078             this.el.enable_tree_lines = true;
1079             this.el.headers_visible = true;
1080             var child_0 = new Xcls_model( _this );
1081             child_0.ref();
1082             this.el.set_model (  child_0.el  );
1083             var child_1 = new Xcls_keycol( _this );
1084             child_1.ref();
1085             this.el.append_column (  child_1.el  );
1086             var child_2 = new Xcls_valcol( _this );
1087             child_2.ref();
1088             this.el.append_column (  child_2.el  );
1089             var child_3 = new Xcls_ContextMenu( _this );
1090             child_3.ref();
1091
1092             // init method 
1093
1094             {
1095                 var selection = this.el.get_selection();
1096                 selection.set_mode( Gtk.SelectionMode.SINGLE);
1097             
1098             
1099                 var description = new Pango.FontDescription();
1100                 description.set_size(8000);
1101                 this.el.modify_font(description);
1102             }
1103             // listeners 
1104             this.el.button_press_event.connect( ( ev)  => {
1105              
1106                 Gtk.TreeViewColumn col;
1107                 int cell_x;
1108                 int cell_y;
1109                 Gtk.TreePath path;
1110                 if (!this.el.get_path_at_pos((int)ev.x, (int) ev.y, out path, out col, out cell_x, out cell_y )) {
1111                     print("nothing selected on click");
1112                     GLib.Timeout.add_full(GLib.Priority.DEFAULT,10 , () => {
1113                         this.el.get_selection().unselect_all();
1114             
1115                         return false;
1116                     });
1117                      _this.before_edit();
1118                     return false; //not on a element.
1119                 }
1120                 
1121                 
1122                  // right click.
1123                  if (ev.type == Gdk.EventType.2BUTTON_PRESS  && ev.button == 1 && col.title == "Name") {    
1124                     // show popup!.   
1125                     
1126              
1127                      _this.before_edit();
1128                      
1129                      _this.keyrender.el.stop_editing(false);
1130                      _this.keyrender.el.editable  =false;
1131                 
1132                      _this.valrender.el.stop_editing(false);
1133                      _this.valrender.el.editable  =false;
1134                        
1135                       _this.startEditingKey(path); 
1136                      
1137                     return false;
1138                 }
1139                 
1140                 
1141                 
1142                 
1143                  // right click.
1144                  if (ev.type == Gdk.EventType.BUTTON_PRESS  && ev.button == 3) {    
1145                     // show popup!.   
1146                     //if (col.title == "Value") {
1147                      //     _this.before_edit();
1148                      //    return false;
1149                      //}
1150             
1151                     var p = _this.ContextMenu;
1152             
1153                     p.el.set_screen(Gdk.Screen.get_default());
1154                     p.el.show_all();
1155                     p.el.popup(null, null, null,  ev.button, ev.time);
1156                     //Seed.print("click:" + res.column.title);
1157                     // select the 
1158                     GLib.Timeout.add_full(GLib.Priority.DEFAULT,10 , () => {
1159               
1160                         this.el.get_selection().select_path(path);
1161                         return false;
1162                     });
1163                      _this.before_edit();
1164                     return false;
1165                 }
1166                 
1167                  
1168                 if (col.title != "Value") {
1169                     print("col title != Value");
1170                     
1171                     GLib.Timeout.add_full(GLib.Priority.DEFAULT,10 , () => {
1172                         this.el.get_selection().select_path(path);
1173                         return false;
1174                     });
1175                     
1176                     _this.before_edit();
1177                       //  XObject.error("column is not value?");
1178                     return false; // ignore.. - key click.. ??? should we do this??
1179                 }
1180                 
1181                 
1182                 // if the cell can be edited with a pulldown
1183                 // then we should return true... - and let the start_editing handle it?
1184                 
1185                 
1186                 
1187                 
1188                 
1189                   
1190                //             _this.before_edit(); <<< we really need to stop the other editor..
1191                  _this.keyrender.el.stop_editing(false);
1192                 _this.keyrender.el.editable  =false;
1193                 
1194                        
1195                 return _this.startEditingValue(path); // assumes selected row..
1196                     
1197                
1198             
1199                           
1200                
1201             });
1202         }
1203
1204         // user defined functions 
1205     }
1206     public class Xcls_model : Object 
1207     {
1208         public Gtk.TreeStore el;
1209         private Xcls_LeftProps  _this;
1210
1211
1212             // my vars (def)
1213
1214         // ctor 
1215         public Xcls_model(Xcls_LeftProps _owner )
1216         {
1217             _this = _owner;
1218             _this.model = this;
1219             this.el = new Gtk.TreeStore( 7,      typeof(string),  // 0 key type
1220      typeof(string),  // 1 key
1221      typeof(string),  // 2 key (display)
1222      typeof(string),  // 3 value
1223      typeof(string),   // 4 value (display)
1224      typeof(string),   // 5 both (tooltip)     
1225      typeof(string)   // 6 key (for sorting)
1226  );
1227
1228             // my vars (dec)
1229
1230             // set gobject values
1231         }
1232
1233         // user defined functions 
1234     }
1235     public class Xcls_keycol : Object 
1236     {
1237         public Gtk.TreeViewColumn el;
1238         private Xcls_LeftProps  _this;
1239
1240
1241             // my vars (def)
1242
1243         // ctor 
1244         public Xcls_keycol(Xcls_LeftProps _owner )
1245         {
1246             _this = _owner;
1247             _this.keycol = this;
1248             this.el = new Gtk.TreeViewColumn();
1249
1250             // my vars (dec)
1251
1252             // set gobject values
1253             this.el.title = "Name";
1254             this.el.resizable = true;
1255             var child_0 = new Xcls_keyrender( _this );
1256             child_0.ref();
1257             this.el.pack_start (  child_0.el , false );
1258
1259             // init method 
1260
1261             this.el.add_attribute(_this.keyrender.el , "markup", 2 );
1262              this.el.add_attribute(_this.keyrender.el , "text", 1 );        }
1263
1264         // user defined functions 
1265     }
1266     public class Xcls_keyrender : Object 
1267     {
1268         public Gtk.CellRendererText el;
1269         private Xcls_LeftProps  _this;
1270
1271
1272             // my vars (def)
1273
1274         // ctor 
1275         public Xcls_keyrender(Xcls_LeftProps _owner )
1276         {
1277             _this = _owner;
1278             _this.keyrender = this;
1279             this.el = new Gtk.CellRendererText();
1280
1281             // my vars (dec)
1282
1283             // set gobject values
1284
1285             // listeners 
1286             this.el.editing_started.connect( (  editable, path) => {
1287             
1288                  Gtk.TreeIter  iter;
1289                 _this.model.el.get_iter(out iter, new Gtk.TreePath.from_string(path));
1290                 GLib.Value gval;
1291                               
1292             
1293             
1294                  //   this.get('/LeftPanel.model').activePath  = path;
1295                 _this.model.el.get_value(iter,1, out gval);
1296                     var val = (string)gval;
1297                              
1298                     ((Gtk.Entry)editable).set_text(val);                 
1299             });
1300             this.el.edited.connect( (path, newtext) => {
1301                     print("Keyrender  - signal:edited\n");
1302                 
1303                 this.el.editable = false;
1304               
1305              
1306             
1307                     Gtk.TreeIter  iter;
1308                     _this.model.el.get_iter(out iter, new Gtk.TreePath.from_string(path));
1309                     GLib.Value gval;
1310                     
1311                      _this.model.el.get_value(iter,1, out gval);
1312                     var oldval = (string)gval;
1313                     
1314                      _this.model.el.get_value(iter,0, out gval);
1315                     var ktype = (string)gval;
1316                    
1317                     _this.model.el.set_value(iter, 1, newtext);
1318                     
1319                     if (oldval == newtext) {
1320                         return;
1321                     }
1322                     
1323                     
1324                     print("ktype: %s\n",ktype);
1325                     switch(ktype) {
1326                         case "listener":
1327                             var ov = _this.node.listeners.get(oldval);
1328                             _this.node.listeners.set(newtext, ov);
1329                             _this.node.listeners.remove(oldval);
1330                             
1331                             _this.updateIter(iter,  ktype, newtext, ov);
1332                             
1333                             break;
1334                         case "props":
1335                             var ov = _this.node.props.get(oldval);
1336                             _this.node.props.set(newtext, ov);
1337                             _this.node.props.remove(oldval);
1338                             _this.updateIter(iter,  ktype, newtext, ov);
1339                             break;
1340                      }
1341                      _this.changed();
1342                       
1343             });
1344         }
1345
1346         // user defined functions 
1347     }
1348     public class Xcls_valcol : Object 
1349     {
1350         public Gtk.TreeViewColumn el;
1351         private Xcls_LeftProps  _this;
1352
1353
1354             // my vars (def)
1355
1356         // ctor 
1357         public Xcls_valcol(Xcls_LeftProps _owner )
1358         {
1359             _this = _owner;
1360             _this.valcol = this;
1361             this.el = new Gtk.TreeViewColumn();
1362
1363             // my vars (dec)
1364
1365             // set gobject values
1366             this.el.title = "Value";
1367             this.el.resizable = true;
1368             var child_0 = new Xcls_valrender( _this );
1369             child_0.ref();
1370             this.el.pack_start (  child_0.el , true );
1371
1372             // init method 
1373
1374             {
1375                 
1376                 //     typeof(string),  // 0 key type
1377                 // typeof(string),  // 1 key
1378                 // typeof(string),  // 2 key (display)
1379                 // typeof(string),  // 3 value
1380                 // typeof(string)   // 4 value (display)
1381             
1382                 
1383                 this.el.add_attribute(_this.valrender.el , "text", 4 );
1384                 //this.el.add_attribute(_this.valrender.el , "sensitive", 4 );
1385                 //this.el.add_attribute(this.items[0].el , 'editable', 3 );
1386                       // this.el.set_cell_data_func(cell, age_cell_data_func, NULL, NULL);
1387             
1388              // this.get('/LeftPanel').editableColumn= this;
1389             }        }
1390
1391         // user defined functions 
1392     }
1393     public class Xcls_valrender : Object 
1394     {
1395         public Gtk.CellRendererCombo el;
1396         private Xcls_LeftProps  _this;
1397
1398
1399             // my vars (def)
1400
1401         // ctor 
1402         public Xcls_valrender(Xcls_LeftProps _owner )
1403         {
1404             _this = _owner;
1405             _this.valrender = this;
1406             this.el = new Gtk.CellRendererCombo();
1407
1408             // my vars (dec)
1409
1410             // set gobject values
1411             this.el.editable = false;
1412             this.el.text_column = 0;
1413             this.el.has_entry = true;
1414             var child_0 = new Xcls_valrendermodel( _this );
1415             child_0.ref();
1416             this.el.model = child_0.el;
1417
1418             // listeners 
1419             this.el.editing_started.connect( ( editable, path) => {
1420                 //_this.editing = true;
1421                 print("editing started called\n");
1422                 if (!_this.allow_edit) {
1423                    
1424                      print("val - editing_Started\n");
1425                     this.el.editable = false; // make sure it's not editor...
1426                
1427                      
1428                     return;
1429                 }
1430                  _this.allow_edit =false;
1431                 
1432                
1433                  if (       this.el.has_entry ) {
1434                
1435                      Gtk.TreeIter  iter;
1436                     _this.model.el.get_iter(out iter, new Gtk.TreePath.from_string(path));
1437                     GLib.Value gval;
1438                                   
1439             
1440                   
1441                      //   this.get('/LeftPanel.model').activePath  = path;
1442                    _this.model.el.get_value(iter,3, out gval);
1443                 
1444             
1445                     var val = (string)gval;
1446                     var combo =        (Gtk.ComboBox)editable;
1447             
1448                    var entry =  (Gtk.Entry) combo.get_child();        
1449                 entry.set_text(val);
1450                 }
1451                
1452             });
1453             this.el.edited.connect( (path, newtext) => {
1454                 print("Valrender  - signal:edited\n");
1455               
1456                     this.el.editable = false;
1457             /*  
1458              m.set(iter, 
1459                             0, "listener",
1460                             1, miter.get_key(),
1461                             2, "<b>" + miter.get_key() + "</b>",
1462                             3, miter.get_value(),
1463                             4, display_value(short);
1464                         ); 
1465             
1466               */      
1467             
1468                     Gtk.TreeIter  iter;
1469                     _this.model.el.get_iter(out iter, new Gtk.TreePath.from_string(path));
1470                     GLib.Value gval;
1471                     
1472                      _this.model.el.get_value(iter,0, out gval);
1473                     var ktype = (string)gval;
1474                     
1475                     
1476                      _this.model.el.get_value(iter,3, out gval);
1477                     var oldval = (string)gval;
1478                     
1479                      _this.model.el.get_value(iter,1, out gval);
1480                     var key = (string)gval;
1481                     
1482                      
1483                     
1484                     switch(ktype) {
1485                         case "listener":
1486                             _this.node.listeners.set(key, newtext);
1487                             _this.updateIter(iter,ktype,key,newtext);
1488                             break;
1489                         case "props":
1490                             _this.node.props.set(key,newtext);
1491                             _this.updateIter(iter,ktype, key,newtext);                
1492                             break;
1493                      }
1494             //         _this.load(_this.file,_this.node);
1495                      _this.changed();
1496                       
1497             });
1498         }
1499
1500         // user defined functions 
1501         public              void setOptions (string[] ar) {
1502               var m = _this.valrendermodel.el;
1503                 m.clear();
1504              Gtk.TreeIter iret;
1505             for (var i =0; i < ar.length; i++) {
1506                     m.append(out iret);
1507                     m.set_value(iret, 0, ar[i]);
1508             }
1509         
1510         }
1511     }
1512     public class Xcls_valrendermodel : Object 
1513     {
1514         public Gtk.ListStore el;
1515         private Xcls_LeftProps  _this;
1516
1517
1518             // my vars (def)
1519
1520         // ctor 
1521         public Xcls_valrendermodel(Xcls_LeftProps _owner )
1522         {
1523             _this = _owner;
1524             _this.valrendermodel = this;
1525             this.el = new Gtk.ListStore( 1, typeof(string) );
1526
1527             // my vars (dec)
1528
1529             // set gobject values
1530         }
1531
1532         // user defined functions 
1533     }
1534     public class Xcls_ContextMenu : Object 
1535     {
1536         public Gtk.Menu el;
1537         private Xcls_LeftProps  _this;
1538
1539
1540             // my vars (def)
1541
1542         // ctor 
1543         public Xcls_ContextMenu(Xcls_LeftProps _owner )
1544         {
1545             _this = _owner;
1546             _this.ContextMenu = this;
1547             this.el = new Gtk.Menu();
1548
1549             // my vars (dec)
1550
1551             // set gobject values
1552             var child_0 = new Xcls_MenuItem28( _this );
1553             child_0.ref();
1554             this.el.append (  child_0.el  );
1555             var child_1 = new Xcls_SeparatorMenuItem29( _this );
1556             child_1.ref();
1557             this.el.append (  child_1.el  );
1558             var child_2 = new Xcls_MenuItem30( _this );
1559             child_2.ref();
1560             this.el.append (  child_2.el  );
1561         }
1562
1563         // user defined functions 
1564     }
1565     public class Xcls_MenuItem28 : Object 
1566     {
1567         public Gtk.MenuItem el;
1568         private Xcls_LeftProps  _this;
1569
1570
1571             // my vars (def)
1572
1573         // ctor 
1574         public Xcls_MenuItem28(Xcls_LeftProps _owner )
1575         {
1576             _this = _owner;
1577             this.el = new Gtk.MenuItem();
1578
1579             // my vars (dec)
1580
1581             // set gobject values
1582             this.el.label = "Edit";
1583
1584             // listeners 
1585             this.el.activate.connect( ( )  =>{
1586               
1587                 var s = _this.view.el.get_selection();
1588                 Gtk.TreeIter iter;
1589                 Gtk.TreeModel model;
1590                 s.get_selected (out  model, out  iter);
1591                 _this.startEditingKey(model.get_path(iter));
1592             });
1593         }
1594
1595         // user defined functions 
1596     }
1597     public class Xcls_SeparatorMenuItem29 : Object 
1598     {
1599         public Gtk.SeparatorMenuItem el;
1600         private Xcls_LeftProps  _this;
1601
1602
1603             // my vars (def)
1604
1605         // ctor 
1606         public Xcls_SeparatorMenuItem29(Xcls_LeftProps _owner )
1607         {
1608             _this = _owner;
1609             this.el = new Gtk.SeparatorMenuItem();
1610
1611             // my vars (dec)
1612
1613             // set gobject values
1614         }
1615
1616         // user defined functions 
1617     }
1618     public class Xcls_MenuItem30 : Object 
1619     {
1620         public Gtk.MenuItem el;
1621         private Xcls_LeftProps  _this;
1622
1623
1624             // my vars (def)
1625
1626         // ctor 
1627         public Xcls_MenuItem30(Xcls_LeftProps _owner )
1628         {
1629             _this = _owner;
1630             this.el = new Gtk.MenuItem();
1631
1632             // my vars (dec)
1633
1634             // set gobject values
1635             this.el.label = "Delete";
1636
1637             // listeners 
1638             this.el.activate.connect( ( )  =>{
1639                 _this.deleteSelected();
1640             });
1641         }
1642
1643         // user defined functions 
1644     }
1645 }