~ubuntu-branches/ubuntu/saucy/unity-tweak-tool/saucy-proposed

« back to all changes in this revision

Viewing changes to UnityTweakTool/elements/cbox.py

  • Committer: Package Import Robot
  • Author(s): Barneedhar Vigneshwar
  • Date: 2013-02-15 20:33:41 UTC
  • Revision ID: package-import@ubuntu.com-20130215203341-yqrfr9df488k41am
Tags: 0.0.3
* New upstream release
* Closes needs-packaging bug (LP: #1126433)

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
#!/usr/bin/env python3
 
2
# -*- coding: utf-8 -*-
 
3
#
 
4
# Team:
 
5
#   J Phani Mahesh <phanimahesh@gmail.com>
 
6
#   Barneedhar (jokerdino) <barneedhar@ubuntu.com>
 
7
#   Amith KK <amithkumaran@gmail.com>
 
8
#   Georgi Karavasilev <motorslav@gmail.com>
 
9
#   Sam Tran <samvtran@gmail.com>
 
10
#   Sam Hewitt <hewittsamuel@gmail.com>
 
11
#   Angel Araya <al.arayaq@gmail.com>
 
12
#
 
13
# Description:
 
14
#   A One-stop configuration tool for Unity.
 
15
#
 
16
# Legal Stuff:
 
17
#
 
18
# This file is a part of Unity Tweak Tool
 
19
#
 
20
# Unity Tweak Tool is free software; you can redistribute it and/or modify it under
 
21
# the terms of the GNU General Public License as published by the Free Software
 
22
# Foundation; version 3.
 
23
#
 
24
# Unity Tweak Tool is distributed in the hope that it will be useful, but WITHOUT
 
25
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
 
26
# FOR A PARTICULAR PURPOSE.  See the GNU General Public License for more
 
27
# details.
 
28
#
 
29
# You should have received a copy of the GNU General Public License along with
 
30
# this program; if not, see <https://www.gnu.org/licenses/gpl-3.0.txt>
 
31
 
 
32
''' Definitions for cbox element. '''
 
33
from UnityTweakTool.backends import gsettings
 
34
 
 
35
import logging
 
36
logger=logging.getLogger('UnityTweakTool.elements.cbox')
 
37
 
 
38
class ComboBox:
 
39
    def __init__(self,controlObj):
 
40
        ''' Initialise a ComboBox element from a dictionary'''
 
41
        self.id         = controlObj['id']
 
42
        self.ui         = controlObj['builder'].get_object(controlObj['id'])
 
43
        self.schema     = controlObj['schema']
 
44
        self.path       = controlObj['path']
 
45
        self.key        = controlObj['key']
 
46
        self.type       = controlObj['type']
 
47
        self.map        = controlObj['map']
 
48
        self.invmap     = dict([ (v,k) for (k,v) in self.map.items() ])
 
49
        assert gsettings.is_valid(
 
50
            schema=self.schema,
 
51
            path=self.path,
 
52
            key=self.key
 
53
            )
 
54
        logger.debug('Initialised a ComboBox with id {self.id} to control key {self.key} of type {self.type} in schema {self.schema} with path {self.path}'.format(self=self))
 
55
 
 
56
    def register(self,handler):
 
57
        ''' register handler on a handler object '''
 
58
        handler['on_%s_changed'%self.id]=self.handler
 
59
        logger.debug('Handler for {self.id} registered'.format(self=self))
 
60
 
 
61
    def refresh(self):
 
62
        ''' Refresh UI reading from backend '''
 
63
        logger.debug('Refreshing UI display for {self.id}'.format(self=self))
 
64
        self.ui.set_active(
 
65
            self.map[
 
66
                gsettings.get(
 
67
                    schema=self.schema,
 
68
                    path  =self.path,
 
69
                    key   =self.key,
 
70
                    type  =self.type
 
71
                    )
 
72
                ]
 
73
            )
 
74
 
 
75
    def handler(self,*args,**kwargs):
 
76
        ''' handle toggle signals '''
 
77
        gsettings.set(
 
78
            schema=self.schema,
 
79
            path=self.path,
 
80
            key=self.key,
 
81
            type=self.type,
 
82
            value=self.invmap[self.ui.get_active()]
 
83
            )
 
84
        logger.info('Handler for {self.id} executed'.format(self=self))
 
85
 
 
86
    def reset(self):
 
87
        ''' Reset the controlled key '''
 
88
        gsettings.reset(schema=self.schema,path=self.path,key=self.key)
 
89
        logger.debug('Key {self.key} in schema {self.schema} and path {self.path} reset.'.format(self=self))