X-Git-Url: http://git.roojs.org/?p=gitlive;a=blobdiff_plain;f=NewBranch.vala;h=7985727f3e973bbdb8c4e6ff74dd5c8daa951f27;hp=d725d32766de76c561af492fb37f0aaf5a68f034;hb=a985c70e9406cefc765b00f947df24d53346012b;hpb=730c5ff2923f1782ebf717efb8337e535b3b3ea0 diff --git a/NewBranch.vala b/NewBranch.vala index d725d327..7985727f 100644 --- a/NewBranch.vala +++ b/NewBranch.vala @@ -12,9 +12,11 @@ public class NewBranch : Object } return _NewBranch; } + public Xcls_notebook notebook; public Xcls_label_select_ticket label_select_ticket; public Xcls_label_create_ticket label_create_ticket; public Xcls_label_quick_commit label_quick_commit; + public Xcls_select_ticket_tab select_ticket_tab; public Xcls_projectsel projectsel; public Xcls_prcellrenderer prcellrenderer; public Xcls_prmodel prmodel; @@ -22,15 +24,16 @@ public class NewBranch : Object public Xcls_dbcellrenderer dbcellrenderer; public Xcls_dbmodel dbmodel; public Xcls_name name; - public Xcls_createbtn createbtn; + public Xcls_branchbtn branchbtn; public Xcls_btn_not_me btn_not_me; public Xcls_btn_closed btn_closed; public Xcls_scrolled_window scrolled_window; public Xcls_view view; + public Xcls_create_ticket_tab create_ticket_tab; public Xcls_table table; public Xcls_project_id project_id; - public Xcls_prcellrenderer prcellrenderer; - public Xcls_prmodel prmodel; + public Xcls_tprcellrenderer tprcellrenderer; + public Xcls_tprmodel tprmodel; public Xcls_summary summary; public Xcls_milestone_id milestone_id; public Xcls_msmodel msmodel; @@ -43,16 +46,11 @@ public class NewBranch : Object public Xcls_clmodel clmodel; public Xcls_developer_id developer_id; public Xcls_devmodel devmodel; - public Xcls_projectsel projectsel; - public Xcls_prcellrenderer prcellrenderer; - public Xcls_prmodel prmodel; - public Xcls_ticketsel ticketsel; - public Xcls_dbcellrenderer dbcellrenderer; - public Xcls_dbmodel dbmodel; - public Xcls_name name; + public Xcls_spinner spinner; + public Xcls_quick_commit_tab quick_commit_tab; + public Xcls_commit_message commit_message; public Xcls_createbtn createbtn; - public Xcls_btn_not_me btn_not_me; - public Xcls_btn_closed btn_closed; + public Xcls_diff_view diff_view; // my vars (def) public GitRepo? repo; @@ -76,7 +74,7 @@ public class NewBranch : Object this.el.default_width = 500; this.el.deletable = true; this.el.modal = true; - var child_0 = new Xcls_Notebook2( _this ); + var child_0 = new Xcls_notebook( _this ); child_0.ref(); this.el.get_content_area().add ( child_0.el ); @@ -108,22 +106,34 @@ public class NewBranch : Object return; } - var ticket_id = _this.ticketsel.selectedTicketId(); + switch(response_id) { + case 1: - if (this.repo != null) { - var bn = _this.name.el.get_text(); - - var res = this.repo.setActiveTicket( - RooTicket.singleton().getById(ticket_id != "" ? ticket_id : "-1"), bn - ); - if (res) { - // start the monitoring.. - GitMonitor.gitmonitor.start(); - - } - } - + + var ticket_id = _this.ticketsel.selectedTicketId(); + + if (this.repo != null) { + var bn = _this.name.el.get_text(); + var res = this.repo.setActiveTicket( + RooTicket.singleton().getById(ticket_id != "" ? ticket_id : "-1"), bn + ); + if (res) { + // start the monitoring.. + GitMonitor.gitmonitor.start(); + + } + } + break; + case 2: // create ticket + branch + break; + + case 3: // just commit... + + break; + default: + break; + } this.running = false; this.el.hide(); @@ -141,43 +151,41 @@ public class NewBranch : Object if (this.running) { // should not happen!! GLib.error("new branch show called, when already being displayed?"); } - this.queue = queue; + + this.queue = queue; this.running = true; GitMonitor.gitmonitor.stop(); + this.repo = repo; - - - this.el.move((Gdk.Screen.width() / 2)- 250 ,0); this.el.set_default_size( 500,200); // not sure why it grows.. - GLib.debug("Loading tickets"); + + + + this.el.show_all(); this.el.set_keep_above(true); + + _this.notebook.el.set_current_page(0); + + _this.select_ticket_tab.load_data(tid); + //_this.create_ticket_tab.load_data(); + //_this.quick_commit_tab.load_data(); + _this.commit_message.el.set_text(""); - var curproj = RooProject.getProjectByRepo(this.repo); - _this.prmodel.loadProjects(curproj == null ? "" : curproj.id); - _this.dbmodel.loadTickets(curproj == null ? "": curproj.id, tid); - _this.createbtn.updateState(); - - _this.ticketsel.el.get_child().get_style_context().remove_class("warning"); - if (tid != "") { - var name = RooTicket.singleton().usernameLocal(); - var ticket = RooTicket.singleton().getById(tid); - _this.name.el.set_text("wip_%s_T%s_%s".printf(name,ticket.id, ticket.summaryToBranchName())); - } else { - _this.ticketsel.el.get_child().get_style_context().add_class("warning"); - } - _this.view.loadTicket(tid); + + + this.el.run(); } - public class Xcls_Notebook2 : Object + public class Xcls_notebook : Object { public Gtk.Notebook el; private NewBranch _this; @@ -186,9 +194,10 @@ public class NewBranch : Object // my vars (def) // ctor - public Xcls_Notebook2(NewBranch _owner ) + public Xcls_notebook(NewBranch _owner ) { _this = _owner; + _this.notebook = this; this.el = new Gtk.Notebook(); // my vars (dec) @@ -201,15 +210,32 @@ public class NewBranch : Object child_1.ref(); var child_2 = new Xcls_label_quick_commit( _this ); child_2.ref(); - var child_3 = new Xcls_Box6( _this ); + var child_3 = new Xcls_select_ticket_tab( _this ); child_3.ref(); this.el.append_page ( child_3.el , _this.label_select_ticket.el ); - var child_4 = new Xcls_Box25( _this ); + var child_4 = new Xcls_create_ticket_tab( _this ); child_4.ref(); this.el.append_page ( child_4.el , _this.label_create_ticket.el ); - var child_5 = new Xcls_Box51( _this ); + var child_5 = new Xcls_quick_commit_tab( _this ); child_5.ref(); this.el.append_page ( child_5.el , _this.label_quick_commit.el ); + + //listeners + this.el.switch_page.connect( (page, page_num) => { + GLib.debug("Switch to page: %d", (int)page_num); + switch(page_num) { + case 0: + break; // do nothing.. it's already loaded at start. + case 1: + _this.create_ticket_tab.load_data(); + break; + case 2: + _this.quick_commit_tab.load_data(); + break; + default: + break; + } + }); } // user defined functions @@ -283,7 +309,7 @@ public class NewBranch : Object // user defined functions } - public class Xcls_Box6 : Object + public class Xcls_select_ticket_tab : Object { public Gtk.Box el; private NewBranch _this; @@ -292,9 +318,10 @@ public class NewBranch : Object // my vars (def) // ctor - public Xcls_Box6(NewBranch _owner ) + public Xcls_select_ticket_tab(NewBranch _owner ) { _this = _owner; + _this.select_ticket_tab = this; this.el = new Gtk.Box( Gtk.Orientation.VERTICAL, 0 ); // my vars (dec) @@ -310,6 +337,28 @@ public class NewBranch : Object } // user defined functions + public void load_data (string tid = "") { + + GLib.debug("Loading tickets"); + + var curproj = RooProject.getProjectByRepo(_this.repo); + _this.prmodel.loadProjects(curproj == null ? "" : curproj.id); + + _this.dbmodel.loadTickets(curproj == null ? "": curproj.id, tid); + _this.branchbtn.updateState(); + + _this.ticketsel.el.get_child().get_style_context().remove_class("warning"); + if (tid != "") { + var name = RooTicket.singleton().usernameLocal(); + var ticket = RooTicket.singleton().getById(tid); + _this.name.el.set_text("wip_%s_T%s_%s".printf(name,ticket.id, ticket.summaryToBranchName())); + } else { + _this.ticketsel.el.get_child().get_style_context().add_class("warning"); + } + _this.view.loadTicket(tid); + + + } } public class Xcls_Table7 : Object { @@ -350,7 +399,7 @@ public class NewBranch : Object var child_5 = new Xcls_name( _this ); child_5.ref(); this.el.attach_defaults ( child_5.el , 0,4,4,5 ); - var child_6 = new Xcls_createbtn( _this ); + var child_6 = new Xcls_branchbtn( _this ); child_6.ref(); this.el.attach_defaults ( child_6.el , 4,5,4,5 ); var child_7 = new Xcls_Box19( _this ); @@ -633,7 +682,7 @@ public class NewBranch : Object _this.scrolled_window.el.show(); _this.view.loadTicket(ticket.id); - _this.createbtn.updateState(); + _this.branchbtn.updateState(); //GLib.debug (//"Selection: %s, %s\n", (string) val1, (string) val2); }); @@ -795,7 +844,7 @@ public class NewBranch : Object // user defined functions } - public class Xcls_createbtn : Object + public class Xcls_branchbtn : Object { public Gtk.Button el; private NewBranch _this; @@ -804,10 +853,10 @@ public class NewBranch : Object // my vars (def) // ctor - public Xcls_createbtn(NewBranch _owner ) + public Xcls_branchbtn(NewBranch _owner ) { _this = _owner; - _this.createbtn = this; + _this.branchbtn = this; this.el = new Gtk.Button(); // my vars (dec) @@ -1060,7 +1109,7 @@ public class NewBranch : Object - public class Xcls_Box25 : Object + public class Xcls_create_ticket_tab : Object { public Gtk.Box el; private NewBranch _this; @@ -1069,9 +1118,10 @@ public class NewBranch : Object // my vars (def) // ctor - public Xcls_Box25(NewBranch _owner ) + public Xcls_create_ticket_tab(NewBranch _owner ) { _this = _owner; + _this.create_ticket_tab = this; this.el = new Gtk.Box( Gtk.Orientation.VERTICAL, 0 ); // my vars (dec) @@ -1081,9 +1131,49 @@ public class NewBranch : Object var child_0 = new Xcls_table( _this ); child_0.ref(); this.el.pack_start ( child_0.el , false,false,0 ); + var child_1 = new Xcls_spinner( _this ); + child_1.ref(); + this.el.add ( child_1.el ); } // user defined functions + public void load_data () { + + _this.table.el.hide(); + _this.spinner.el.show(); + _this.spinner.el.start(); + + Timeout.add_seconds(1, () => { + + RooProject? curproj = null; + if (_this.repo != null) { + curproj = RooProject.getProjectByRepo(_this.repo); + } + _this.tprmodel.loadProjects(curproj == null ? "" : curproj.id); + if (curproj != null) { + + + var rt = RooTicket.singleton(); + rt.loadProjectOptions(curproj.id); + + _this.msmodel.loadMilestones(); + _this.primodel.loadPriorities(); + _this.sevmodel.loadSeverities(); + _this.clmodel.loadClassifications(); + _this.devmodel.loadDevelopers(); + + } + _this.summary.el.set_text(""); + _this.description.el.buffer.text = ""; + _this.spinner.el.stop(); + _this.spinner.el.hide(); + + _this.table.el.show(); + //_this.summary.el.grab_focus(); + + return false; + }); + } } public class Xcls_table : Object { @@ -1230,10 +1320,10 @@ public class NewBranch : Object this.loading = false; // set gobject values - var child_0 = new Xcls_prcellrenderer( _this ); + var child_0 = new Xcls_tprcellrenderer( _this ); child_0.ref(); this.el.pack_start ( child_0.el , true ); - var child_1 = new Xcls_prmodel( _this ); + var child_1 = new Xcls_tprmodel( _this ); child_1.ref(); this.el.set_model ( child_1.el ); @@ -1291,7 +1381,7 @@ public class NewBranch : Object this.el.get_active_iter (out iter); - _this.prmodel.el.get_value (iter, 0, out val1); + _this.tprmodel.el.get_value (iter, 0, out val1); return (string) val1; @@ -1301,7 +1391,7 @@ public class NewBranch : Object } } - public class Xcls_prcellrenderer : Object + public class Xcls_tprcellrenderer : Object { public Gtk.CellRendererText el; private NewBranch _this; @@ -1310,10 +1400,10 @@ public class NewBranch : Object // my vars (def) // ctor - public Xcls_prcellrenderer(NewBranch _owner ) + public Xcls_tprcellrenderer(NewBranch _owner ) { _this = _owner; - _this.prcellrenderer = this; + _this.tprcellrenderer = this; this.el = new Gtk.CellRendererText(); // my vars (dec) @@ -1324,7 +1414,7 @@ public class NewBranch : Object // user defined functions } - public class Xcls_prmodel : Object + public class Xcls_tprmodel : Object { public Gtk.ListStore el; private NewBranch _this; @@ -1333,10 +1423,10 @@ public class NewBranch : Object // my vars (def) // ctor - public Xcls_prmodel(NewBranch _owner ) + public Xcls_tprmodel(NewBranch _owner ) { _this = _owner; - _this.prmodel = this; + _this.tprmodel = this; this.el = new Gtk.ListStore( 2, typeof(string),typeof(string) ); // my vars (dec) @@ -2161,8 +2251,33 @@ public class NewBranch : Object } + public class Xcls_spinner : Object + { + public Gtk.Spinner el; + private NewBranch _this; + + + // my vars (def) + + // ctor + public Xcls_spinner(NewBranch _owner ) + { + _this = _owner; + _this.spinner = this; + this.el = new Gtk.Spinner(); + + // my vars (dec) + + // set gobject values + this.el.hexpand = true; + this.el.vexpand = true; + } + + // user defined functions + } + - public class Xcls_Box51 : Object + public class Xcls_quick_commit_tab : Object { public Gtk.Box el; private NewBranch _this; @@ -2171,23 +2286,31 @@ public class NewBranch : Object // my vars (def) // ctor - public Xcls_Box51(NewBranch _owner ) + public Xcls_quick_commit_tab(NewBranch _owner ) { _this = _owner; + _this.quick_commit_tab = this; this.el = new Gtk.Box( Gtk.Orientation.VERTICAL, 0 ); // my vars (dec) // set gobject values this.el.homogeneous = false; - var child_0 = new Xcls_Table52( _this ); + var child_0 = new Xcls_Table53( _this ); child_0.ref(); this.el.pack_start ( child_0.el , false,false,0 ); + var child_1 = new Xcls_ScrolledWindow57( _this ); + child_1.ref(); + this.el.add ( child_1.el ); } // user defined functions + public void load_data () { + + _this.createbtn.updateState(); + } } - public class Xcls_Table52 : Object + public class Xcls_Table53 : Object { public Gtk.Table el; private NewBranch _this; @@ -2196,10 +2319,10 @@ public class NewBranch : Object // my vars (def) // ctor - public Xcls_Table52(NewBranch _owner ) + public Xcls_Table53(NewBranch _owner ) { _this = _owner; - this.el = new Gtk.Table( 5, 5, true ); + this.el = new Gtk.Table( 3, 5, true ); // my vars (dec) @@ -2208,35 +2331,20 @@ public class NewBranch : Object this.el.margin = 2; this.el.column_spacing = 4; this.el.vexpand = false; - var child_0 = new Xcls_Label53( _this ); + var child_0 = new Xcls_Label54( _this ); child_0.ref(); this.el.attach_defaults ( child_0.el , 0,1,0,1 ); - var child_1 = new Xcls_Label54( _this ); + var child_1 = new Xcls_commit_message( _this ); child_1.ref(); - this.el.attach_defaults ( child_1.el , 1,2,0,1 ); - var child_2 = new Xcls_projectsel( _this ); + this.el.attach_defaults ( child_1.el , 0,5,1,2 ); + var child_2 = new Xcls_createbtn( _this ); child_2.ref(); - this.el.attach_defaults ( child_2.el , 0,1,1,2 ); - var child_3 = new Xcls_ticketsel( _this ); - child_3.ref(); - this.el.attach_defaults ( child_3.el , 1,5,1,2 ); - var child_4 = new Xcls_Label61( _this ); - child_4.ref(); - this.el.attach_defaults ( child_4.el , 0,1,3,4 ); - var child_5 = new Xcls_name( _this ); - child_5.ref(); - this.el.attach_defaults ( child_5.el , 0,4,4,5 ); - var child_6 = new Xcls_createbtn( _this ); - child_6.ref(); - this.el.attach_defaults ( child_6.el , 4,5,4,5 ); - var child_7 = new Xcls_Box64( _this ); - child_7.ref(); - this.el.attach_defaults ( child_7.el , 0,5,2,3 ); + this.el.attach_defaults ( child_2.el , 0,5,2,3 ); } // user defined functions } - public class Xcls_Label53 : Object + public class Xcls_Label54 : Object { public Gtk.Label el; private NewBranch _this; @@ -2245,619 +2353,165 @@ public class NewBranch : Object // my vars (def) // ctor - public Xcls_Label53(NewBranch _owner ) + public Xcls_Label54(NewBranch _owner ) { _this = _owner; - this.el = new Gtk.Label( "Project" ); + this.el = new Gtk.Label( "Just commit with this comment" ); // my vars (dec) // set gobject values this.el.halign = Gtk.Align.START; this.el.justify = Gtk.Justification.RIGHT; - this.el.visible = true; + this.el.xalign = 0.900000f; } // user defined functions } - public class Xcls_Label54 : Object + public class Xcls_commit_message : Object { - public Gtk.Label el; + public Gtk.Entry el; private NewBranch _this; // my vars (def) // ctor - public Xcls_Label54(NewBranch _owner ) + public Xcls_commit_message(NewBranch _owner ) { _this = _owner; - this.el = new Gtk.Label( "Ticket" ); + _this.commit_message = this; + this.el = new Gtk.Entry(); // my vars (dec) // set gobject values - this.el.halign = Gtk.Align.START; this.el.visible = true; + + //listeners + this.el.key_release_event.connect( () => { + + _this.createbtn.updateState(); + return true; + }); } // user defined functions } - public class Xcls_projectsel : Object + public class Xcls_createbtn : Object { - public Gtk.ComboBox el; + public Gtk.Button el; private NewBranch _this; // my vars (def) - public bool loading; // ctor - public Xcls_projectsel(NewBranch _owner ) + public Xcls_createbtn(NewBranch _owner ) { _this = _owner; - _this.projectsel = this; - this.el = new Gtk.ComboBox.with_entry(); + _this.createbtn = this; + this.el = new Gtk.Button(); // my vars (dec) - this.loading = false; // set gobject values - var child_0 = new Xcls_prcellrenderer( _this ); - child_0.ref(); - this.el.pack_start ( child_0.el , true ); - var child_1 = new Xcls_prmodel( _this ); - child_1.ref(); - this.el.set_model ( child_1.el ); + this.el.label = "Commit Changes"; // init method - this.el.set_entry_text_column(1); + { + this.el.get_style_context().add_class("suggested-action"); + } //listeners - this.el.changed.connect( () => { - if (this.loading) { - return; - } - var project_id = this.selectedProjectId(); - _this.dbmodel.loadTickets(project_id); - - - /*if (this.loading) { - return; - } - var ticket_id = this.selectedTicketId(); - - var name = RooTicket.singleton().usernameLocal(); - - if (ticket_id == "" || ticket_id == null) { - - var dt = new DateTime.now_local(); - _this.name.el.set_text("wip_%s_%s".printf(name,dt.format("%Y_%b_%d"))); - return; - } - - - var ticket = RooTicket.singleton().getById(ticket_id); - - _this.name.el.set_text("wip_%s_T%s_%s".printf(name,ticket.id, ticket.summaryToBranchName())); + this.el.clicked.connect( () => { + + GLib.debug("fire response = 1"); - //GLib.debug (//"Selection: %s, %s\n", (string) val1, (string) val2); - */ + + + _this.el.response(3); }); } // user defined functions - public string selectedProjectId () { - Gtk.TreeIter iter; - Value val1; - - - this.el.get_active_iter (out iter); - _this.prmodel.el.get_value (iter, 0, out val1); - + public void updateState () { - return (string) val1; - - - + var msg = _this.commit_message.el.get_text(); + if (msg == "") { + this.el.set_sensitive(false); + return; + } + + this.el.set_sensitive(true); + } } - public class Xcls_prcellrenderer : Object + + + public class Xcls_ScrolledWindow57 : Object { - public Gtk.CellRendererText el; + public Gtk.ScrolledWindow el; private NewBranch _this; // my vars (def) // ctor - public Xcls_prcellrenderer(NewBranch _owner ) + public Xcls_ScrolledWindow57(NewBranch _owner ) { _this = _owner; - _this.prcellrenderer = this; - this.el = new Gtk.CellRendererText(); + this.el = new Gtk.ScrolledWindow( null, null ); // my vars (dec) // set gobject values + this.el.height_request = 400; + this.el.vexpand = true; + var child_0 = new Xcls_diff_view( _this ); + child_0.ref(); + this.el.add ( child_0.el ); } // user defined functions } - - public class Xcls_prmodel : Object + public class Xcls_diff_view : Object { - public Gtk.ListStore el; + public Gtk.SourceView el; private NewBranch _this; // my vars (def) // ctor - public Xcls_prmodel(NewBranch _owner ) + public Xcls_diff_view(NewBranch _owner ) { _this = _owner; - _this.prmodel = this; - this.el = new Gtk.ListStore( 2, typeof(string),typeof(string) ); + _this.diff_view = this; + this.el = new Gtk.SourceView(); // my vars (dec) - // set gobject values + // init method + + var description = Pango.FontDescription.from_string("monospace"); + description.set_size(9000); + this.el.override_font(description); + var lm = Gtk.SourceLanguageManager.get_default(); + + ((Gtk.SourceBuffer)(this.el.get_buffer())).set_language( + lm.get_language("diff") + ); } // user defined functions - public void loadProjects (string id) { - - - - _this.projectsel.loading = true; - - this.el.clear(); - Gtk.TreeIter iter; - var el = this.el; - - el.append(out iter); - - - el.set_value(iter, 0, ""); - el.set_value(iter, 1, "-- select a project --"); - if (id == "") { - _this.projectsel.el.set_active_iter(iter); - } - - foreach(var project in RooProject.projects()) { - - el.append(out iter); - - el.set_value(iter, 0, project.id); - el.set_value(iter, 1, project.name ); - if (id == project.id) { - _this.projectsel.el.set_active_iter(iter); - } - - } - - _this.projectsel.loading = false; - //this.el.set_sort_column_id(0, Gtk.SortType.ASCENDING); - - } } - public class Xcls_ticketsel : Object - { - public Gtk.ComboBox el; - private NewBranch _this; - - - // my vars (def) - public bool loading; - - // ctor - public Xcls_ticketsel(NewBranch _owner ) - { - _this = _owner; - _this.ticketsel = this; - this.el = new Gtk.ComboBox.with_entry(); - - // my vars (dec) - this.loading = false; - - // set gobject values - var child_0 = new Xcls_dbcellrenderer( _this ); - child_0.ref(); - this.el.pack_start ( child_0.el , true ); - var child_1 = new Xcls_dbmodel( _this ); - child_1.ref(); - this.el.set_model ( child_1.el ); - - // init method - - //this.el.add_attribute(_this.dbcellrenderer.el , "markup", 1 ); - this.el.set_entry_text_column(1); - this.el.get_child().set_sensitive(false); - - //listeners - this.el.changed.connect( () => { - if (this.loading) { - return; - } - var ticket_id = this.selectedTicketId(); - - var name = RooTicket.singleton().usernameLocal(); - - this.el.get_child().get_style_context().remove_class("warning"); - if (ticket_id == "" || ticket_id == null) { - - var dt = new DateTime.now_local(); - _this.name.el.set_text("wip_%s_%s".printf(name,dt.format("%Y_%b_%d"))); - _this.view.loadTicket(""); - - this.el.get_child().get_style_context().add_class("warning"); - _this.createbtn.updateState(); - return; - } - - - var ticket = RooTicket.singleton().getById(ticket_id); - - _this.name.el.set_text("wip_%s_T%s_%s".printf(name,ticket.id, ticket.summaryToBranchName())); - _this.scrolled_window.el.show(); - - _this.view.loadTicket(ticket.id); - _this.createbtn.updateState(); - - //GLib.debug (//"Selection: %s, %s\n", (string) val1, (string) val2); - }); - } - - // user defined functions - public string selectedTicketId () { - Gtk.TreeIter iter; - Value val1; - - - this.el.get_active_iter (out iter); - _this.dbmodel.el.get_value (iter, 0, out val1); - - - return (string) val1; - - - - - } - } - public class Xcls_dbcellrenderer : Object - { - public Gtk.CellRendererText el; - private NewBranch _this; - - - // my vars (def) - - // ctor - public Xcls_dbcellrenderer(NewBranch _owner ) - { - _this = _owner; - _this.dbcellrenderer = this; - this.el = new Gtk.CellRendererText(); - - // my vars (dec) - - // set gobject values - } - - // user defined functions - } - - public class Xcls_dbmodel : Object - { - public Gtk.ListStore el; - private NewBranch _this; - - - // my vars (def) - - // ctor - public Xcls_dbmodel(NewBranch _owner ) - { - _this = _owner; - _this.dbmodel = this; - this.el = new Gtk.ListStore( 2, typeof(string),typeof(string) ); - - // my vars (dec) - - // set gobject values - } - - // user defined functions - public void loadTickets (string project_id , string tid = "") { - - - - // fixme .. get project id from selection.. - - RooTicket.singleton().loadTickets( - project_id, - _this.btn_not_me.el.active ? RooTicket.Who.ANYBODY : RooTicket.Who.ME, - _this.btn_closed.el.active ? RooTicket.Status.ALL : RooTicket.Status.ACTIVE - ); - - _this.ticketsel.loading = true; - - this.el.clear(); - Gtk.TreeIter iter; - var el = this.el; - - el.append(out iter); - - - el.set_value(iter, 0, ""); - el.set_value(iter, 1, "-- select a ticket --"); - - _this.ticketsel.el.set_active_iter(iter); - var tickets = RooTicket.singleton().tickets; - foreach(var ticket in tickets) { - - el.append(out iter); - - el.set_value(iter, 0, ticket.id); - el.set_value(iter, 1, "#%s %s".printf( ticket.id, ticket.summary)); - - if (ticket.id == tid) { - _this.ticketsel.el.set_active_iter(iter); - } - - } - - _this.ticketsel.loading = false; - //this.el.set_sort_column_id(0, Gtk.SortType.ASCENDING); - - } - } - - - public class Xcls_Label61 : Object - { - public Gtk.Label el; - private NewBranch _this; - - - // my vars (def) - - // ctor - public Xcls_Label61(NewBranch _owner ) - { - _this = _owner; - this.el = new Gtk.Label( "Use this as branch name" ); - - // my vars (dec) - - // set gobject values - this.el.halign = Gtk.Align.START; - this.el.justify = Gtk.Justification.RIGHT; - this.el.xalign = 0.900000f; - } - - // user defined functions - } - - public class Xcls_name : Object - { - public Gtk.Entry el; - private NewBranch _this; - - - // my vars (def) - - // ctor - public Xcls_name(NewBranch _owner ) - { - _this = _owner; - _this.name = this; - this.el = new Gtk.Entry(); - - // my vars (dec) - - // set gobject values - this.el.visible = true; - } - - // user defined functions - } - - public class Xcls_createbtn : Object - { - public Gtk.Button el; - private NewBranch _this; - - - // my vars (def) - - // ctor - public Xcls_createbtn(NewBranch _owner ) - { - _this = _owner; - _this.createbtn = this; - this.el = new Gtk.Button(); - - // my vars (dec) - - // set gobject values - this.el.label = "Create Branch"; - - // init method - - { - this.el.get_style_context().add_class("suggested-action"); - } - - //listeners - this.el.clicked.connect( () => { - - GLib.debug("fire response = 1"); - - var ticket_id = _this.ticketsel.selectedTicketId(); - - if (ticket_id == "") { - _this.ticketsel.el.get_child().get_style_context().add_class("warning"); - return; - } - - _this.el.response(1); - }); - } - - // user defined functions - public void updateState () { - - var ticket_id = _this.ticketsel.selectedTicketId(); - - if (ticket_id == "") { - this.el.set_sensitive(false); - return; - } - - this.el.set_sensitive(true); - - } - } - - public class Xcls_Box64 : Object - { - public Gtk.Box el; - private NewBranch _this; - - - // my vars (def) - - // ctor - public Xcls_Box64(NewBranch _owner ) - { - _this = _owner; - this.el = new Gtk.Box( Gtk.Orientation.HORIZONTAL, 0 ); - - // my vars (dec) - - // set gobject values - var child_0 = new Xcls_btn_not_me( _this ); - child_0.ref(); - this.el.add ( child_0.el ); - var child_1 = new Xcls_btn_closed( _this ); - child_1.ref(); - this.el.add ( child_1.el ); - var child_2 = new Xcls_Label67( _this ); - child_2.ref(); - this.el.add ( child_2.el ); - } - - // user defined functions - } - public class Xcls_btn_not_me : Object - { - public Gtk.CheckButton el; - private NewBranch _this; - - - // my vars (def) - - // ctor - public Xcls_btn_not_me(NewBranch _owner ) - { - _this = _owner; - _this.btn_not_me = this; - this.el = new Gtk.CheckButton(); - - // my vars (dec) - - // set gobject values - this.el.label = "Show tickets not assigned to me"; - - //listeners - this.el.toggled.connect( () => { - var project_id = _this.projectsel.selectedProjectId(); - _this.dbmodel.loadTickets(project_id); - }); - } - - // user defined functions - } - - public class Xcls_btn_closed : Object - { - public Gtk.CheckButton el; - private NewBranch _this; - - - // my vars (def) - - // ctor - public Xcls_btn_closed(NewBranch _owner ) - { - _this = _owner; - _this.btn_closed = this; - this.el = new Gtk.CheckButton(); - - // my vars (dec) - - // set gobject values - this.el.label = "Show closed Tickets"; - - //listeners - this.el.toggled.connect( () => { - var project_id = _this.projectsel.selectedProjectId(); - _this.dbmodel.loadTickets(project_id); - - }); - } - - // user defined functions - } - - public class Xcls_Label67 : Object - { - public Gtk.Label el; - private NewBranch _this; - - - // my vars (def) - - // ctor - public Xcls_Label67(NewBranch _owner ) - { - _this = _owner; - this.el = new Gtk.Label( "Refresh Ticket list" ); - - // my vars (dec) - - // set gobject values - this.el.halign = Gtk.Align.END; - this.el.hexpand = true; - this.el.use_markup = true; - - //listeners - this.el.activate_link.connect( (uri) => { - if (uri == "refresh") { - RooProject.reload(); - var curproj = RooProject.getProjectByRepo(_this.repo); - _this.prmodel.loadProjects(curproj == null ? "": curproj.id); - - _this.dbmodel.loadTickets(curproj == null ? "": curproj.id); - } - return true; - }); - } - - // user defined functions - } - - - }