1 """Useful utility methods for GTK."""
2
3
4
5
6 import gtk
7 from zeroinstall.support import tasks
8
10 """Wrapper for GtkBuilder widget tree that throws a sensible exception if the widget isn't found."""
12 """Constructor.
13 @param builderfile: pathname of the .ui file to load
14 @param root: the name of the top-level widget inside the file"""
15 self.builder = gtk.Builder()
16 self.builder.set_translation_domain('zero-install')
17 self.builder.add_from_file(builderfile)
18 self.builderfile = builderfile
19 self.root = root
20
28
30 """Display a non-modal message box with an OK button.
31 @param parent: the parent window
32 @param message: the message to be displayed
33 @param type: the type of box (used for the icon)"""
34 box = gtk.MessageDialog(parent, gtk.DIALOG_DESTROY_WITH_PARENT,
35 type, gtk.BUTTONS_OK,
36 str(message))
37 box.set_position(gtk.WIN_POS_CENTER)
38 def resp(b, r):
39 b.destroy()
40 box.connect('response', resp)
41 box.show()
42
43 _busy_pointer = None
45 """Get a GDK background-activity cursor.
46 Use this when something is happening, but the GUI is still responsive.
47 @return: the busy cursor (a singleton)
48 @rtype: gdk.Cursor
49 """
50 global _busy_pointer
51 if _busy_pointer is not None:
52 return _busy_pointer
53
54
55
56
57
58
59 bit_data = "\
60 \x00\x00\x00\x00\x00\x00\x00\x00\x04\x00\x00\x00\
61 \x0c\x00\x00\x00\x1c\x00\x00\x00\x3c\x00\x00\x00\
62 \x7c\x00\x00\x00\xfc\x00\x00\x00\xfc\x01\x00\x00\
63 \xfc\x3b\x00\x00\x7c\x38\x00\x00\x6c\x54\x00\x00\
64 \xc4\xdc\x00\x00\xc0\x44\x00\x00\x80\x39\x00\x00\
65 \x80\x39\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\
66 \x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\
67 \x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\
68 \x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\
69 \x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\
70 \x00\x00\x00\x00\x00\x00\x00\x00"
71
72 try:
73 pix = gtk.gdk.bitmap_create_from_data(None, bit_data, 32, 32)
74 color = gtk.gdk.Color()
75 _busy_pointer = gtk.gdk.Cursor(pix, pix, color, color, 2, 2)
76 except:
77
78 _busy_pointer = gtk.gdk.Cursor(gtk.gdk.WATCH)
79 return _busy_pointer
80
82 """Triggers when the GtkDialog gets a response.
83 @since: 1.5"""
84 response = None
92 a = dialog.connect('response', response)
93
104
127