summaryrefslogtreecommitdiffstats
path: root/bitbake/lib/bb/ui/crumbs/hobpages.py
blob: 5045ea201925810d2e5c969abf67c32a3e6f87a4 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
#!/usr/bin/env python
#
# BitBake Graphical GTK User Interface
#
# Copyright (C) 2012        Intel Corporation
#
# Authored by Dongxiao Xu <dongxiao.xu@intel.com>
# Authored by Shane Wang <shane.wang@intel.com>
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License version 2 as
# published by the Free Software Foundation.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License along
# with this program; if not, write to the Free Software Foundation, Inc.,
# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.

import gtk
from bb.ui.crumbs.hobcolor import HobColors
from bb.ui.crumbs.hobwidget import hwc

#
# HobPage: the super class for all Hob-related pages
#    
class HobPage (gtk.VBox):

    def __init__(self, builder, title = None):
        super(HobPage, self).__init__(False, 0)
        self.builder = builder
        self.builder_width, self.builder_height = self.builder.size_request()

        if not title:
            self.title = "Hob -- Image Creator"
        else:
            self.title = title

        self.box_group_area = gtk.VBox(False, 12)
        self.box_group_area.set_size_request(self.builder_width - 73 - 73, self.builder_height - 88 - 15 - 15)
        self.group_align = gtk.Alignment(xalign = 0, yalign=0.5, xscale=1, yscale=1)
        self.group_align.set_padding(15, 15, 73, 73)
        self.group_align.add(self.box_group_area)
        self.box_group_area.set_homogeneous(False)


    def add_onto_top_bar(self, widget = None, padding = 0):
        # the top button occupies 1/7 of the page height
        # setup an event box
        eventbox = gtk.EventBox()
        style = eventbox.get_style().copy()
        style.bg[gtk.STATE_NORMAL] = eventbox.get_colormap().alloc_color(HobColors.LIGHT_GRAY, False, False)
        eventbox.set_style(style)
        eventbox.set_size_request(-1, 88)

        hbox = gtk.HBox()

        label = gtk.Label()
        label.set_markup("<span size='x-large'>%s</span>" % self.title)
        hbox.pack_start(label, expand=False, fill=False, padding=20)

        if widget:
            # add the widget in the event box
            hbox.pack_end(widget, expand=False, fill=False, padding=padding)
        eventbox.add(hbox)

        return eventbox

    def span_tag(self, size="medium", weight="normal", forground="#1c1c1c"):
        span_tag = "weight='%s' foreground='%s' size='%s'" % (weight, forground, size)
        return span_tag

    def append_toolbar_button(self, toolbar, buttonname, icon_disp, icon_hovor, tip, cb):
        # Create a button and append it on the toolbar according to button name
        icon = gtk.Image()
        icon_display = icon_disp
        icon_hover = icon_hovor
        pix_buffer = gtk.gdk.pixbuf_new_from_file(icon_display)
        icon.set_from_pixbuf(pix_buffer)
        tip_text = tip
        button = toolbar.append_item(buttonname, tip, None, icon, cb)
        return button

    @staticmethod
    def _size_to_string(size):
        try:
            if not size:
                size_str = "0 B"
            else:
                if len(str(int(size))) > 6:
                    size_str = '%.1f' % (size*1.0/(1024*1024)) + ' MB'
                elif len(str(int(size))) > 3:
                    size_str = '%.1f' % (size*1.0/1024) + ' KB'
                else:
                    size_str = str(size) + ' B'
        except:
            size_str = "0 B"
        return size_str

    @staticmethod
    def _string_to_size(str_size):
        try:
            if not str_size:
                size = 0
            else:
                unit = str_size.split()
                if len(unit) > 1:
                    if unit[1] == 'MB':
                        size = float(unit[0])*1024*1024
                    elif unit[1] == 'KB':
                        size = float(unit[0])*1024
                    elif unit[1] == 'B':
                        size = float(unit[0])
                    else:
                        size = 0
                else:
                    size = float(unit[0])
        except:
            size = 0
        return size