From fc571a9ac7aaa8802d3e8aacf9aefac12ca3c81c Mon Sep 17 00:00:00 2001 From: Jiri Moskovcak Date: Fri, 6 Nov 2009 15:11:37 +0100 Subject: GUI: added support for backtrace rating - we don't allow user to create a bug report with backtrace rated below 3 - gui shows yellow warning if the rating == 3 --- src/Gui/CCReporterDialog.py | 32 ++++++++++++++++++++++++++++++++ src/Gui/report.glade | 35 ++++++++++++++++++++++++++++++++--- 2 files changed, 64 insertions(+), 3 deletions(-) (limited to 'src/Gui') diff --git a/src/Gui/CCReporterDialog.py b/src/Gui/CCReporterDialog.py index 9207a3e5..e1d1c1bb 100644 --- a/src/Gui/CCReporterDialog.py +++ b/src/Gui/CCReporterDialog.py @@ -76,6 +76,8 @@ class ReporterDialog(): # connect the signals self.tvReport.connect_after("size-allocate", self.on_window_resize) self.wTree.get_widget("bSend").connect("clicked", self.on_send_clicked) + # start whit the warning hidden, so it's not visible when there is no rating + self.wTree.get_widget("ebErrors").hide() self.hydrate() # this callback is called when user press Cancel or Report button in Report dialog @@ -180,6 +182,36 @@ class ReporterDialog(): self.tvComment.set_buffer(buff) continue + # if an backtrace has rating use it + if item == "rating": + try: + package = self.report["package"][CONTENT] + # if we don't have package for some reason + except: + package = None + ebErrors = self.wTree.get_widget("ebErrors") + lErrors = self.wTree.get_widget("lErrors") + bSend = self.wTree.get_widget("bSend") + # not usable report + if int(self.report[item][CONTENT]) < 3: + ebErrors.show() + ebErrors.modify_bg(gtk.STATE_NORMAL, gtk.gdk.color_parse("red")) + if package: + lErrors.set_markup( + "%s" % _("Reporting disabled because the backtrace is unusable!\nPlease try to install debuginfo manually using command: debuginfo-install %s \nthen use Refresh button to regenerate the backtrace." % package[0:package.rfind('-',0,package.rfind('-'))])) + else: + lErrors.set_markup("%s" % _("The bactrace is unusable, you can't report this!")) + bSend.set_sensitive(False) + # probably usable 3 + elif int(self.report[item][CONTENT]) < 4: + ebErrors.show() + ebErrors.modify_bg(gtk.STATE_NORMAL, gtk.gdk.color_parse("yellow")) + lErrors.set_markup("%s" % _("The bactrace is incomplete, please make sure you provide good steps to reproduce.")) + bSend.set_sensitive(True) + else: + ebErrors.hide() + bSend.set_sensitive(True) + if self.report[item][TYPE] != 's': # item name 0| value 1| editable? 2| toggled? 3| visible?(attachment)4 if self.report[item][EDITABLE] == 'y': diff --git a/src/Gui/report.glade b/src/Gui/report.glade index 9b582b22..2ccf1690 100644 --- a/src/Gui/report.glade +++ b/src/Gui/report.glade @@ -13,10 +13,12 @@ True + vertical 2 True + vertical True @@ -44,14 +46,35 @@ 1 + + + True + + + True + + True + + + + + False + False + 2 + + 0 + + + True + vertical True @@ -91,7 +114,7 @@ False - 2 + 3 @@ -100,7 +123,7 @@ end - gtk-cancel + gtk-cancel -6 True True @@ -108,12 +131,14 @@ True + False + False 0 - gtk-refresh + gtk-refresh -50 True True @@ -121,6 +146,8 @@ True + False + False 1 @@ -133,6 +160,8 @@ True + False + False 2 -- cgit