diff --git a/chatstate/chatstate.py b/chatstate/chatstate.py index a68a2b1..cd8cf83 100644 --- a/chatstate/chatstate.py +++ b/chatstate/chatstate.py @@ -5,7 +5,6 @@ import gtk import gobject import pango -from plugins.gui import GajimPluginConfigDialog from plugins import GajimPlugin from plugins.helpers import log_calls, log from common import ged @@ -18,15 +17,10 @@ class ChatstatePlugin(GajimPlugin): @log_calls('ChatstatePlugin') def init(self): - self.config_dialog = ChatstatePluginConfigDialog(self) + self.config_dialog = None#ChatstatePluginConfigDialog(self) self.events_handlers = {'raw-message-received' : (ged.POSTCORE, self.raw_pres_received),} - self.config_default_values = { - 'active': ('darkred',''), - 'composing': ('darkgreen', ''), - 'inactive': ('#675B5B',''), - 'paused': ('darkblue', ''),} - self.compose = ('active', 'composing', 'gone', 'inactive', 'paused') + self.chatstates = ('active', 'composing', 'gone', 'inactive', 'paused') self.active = None @@ -39,8 +33,8 @@ class ChatstatePlugin(GajimPlugin): if not contact: return - for compose in self.compose: - state = event_object.xmpp_msg.getTag(compose) + for chatstate in self.chatstates: + state = event_object.xmpp_msg.getTag(chatstate) if state: break if not state: @@ -52,9 +46,25 @@ class ChatstatePlugin(GajimPlugin): for child_iter in child_iters: name = gobject.markup_escape_text(contact.get_shown_name()) - if compose != 'gone': - name = '%s' % ( - self.config[compose], name) + theme = gajim.config.get('roster_theme') + color = None + if chatstate == 'composing': + color = gajim.config.get_per('themes', theme, + 'state_composing_color') + elif chatstate == 'inactive': + color = gajim.config.get_per('themes', theme, + 'state_inactive_color') + elif chatstate == 'gone': + color = gajim.config.get_per('themes', theme, + 'state_gone_color') + elif chatstate == 'paused': + color = gajim.config.get_per('themes', theme, + 'state_paused_color') + elif chatstate == 'active': + color = gajim.config.get('inmsgcolor') + + name = '%s' % ( + color, name) if contact.status and gajim.config.get('show_status_msgs_in_roster'): status = contact.status.strip() if status != '': @@ -78,31 +88,3 @@ class ChatstatePlugin(GajimPlugin): def deactivate(self): self.active = False pass - - -class ChatstatePluginConfigDialog(GajimPluginConfigDialog): - def init(self): - self.GTK_BUILDER_FILE_PATH = self.plugin.local_file_path( - 'config_dialog.ui') - self.xml = gtk.Builder() - self.xml.set_translation_domain('gajim') - self.xml.add_objects_from_file(self.GTK_BUILDER_FILE_PATH, - ['vbox1']) - vbox1 = self.xml.get_object('vbox1') - self.child.pack_start(vbox1) - self.xml.connect_signals(self) - self.connect('hide', self.on_hide) - - def on_run(self): - for name in self.plugin.config_default_values: - widget = self.xml.get_object(name) - widget.set_color(gtk.gdk.color_parse(self.plugin.config[name])) - - def changed(self, entry): - name = gtk.Buildable.get_name(entry) - self.plugin.config[name] = entry.get_text() - - def on_hide(self, widget): - for name in self.plugin.config_default_values: - widget = self.xml.get_object(name) - self.plugin.config[name] = widget.get_color().to_string() diff --git a/chatstate/manifest.ini b/chatstate/manifest.ini index 9def70d..1ef91ed 100644 --- a/chatstate/manifest.ini +++ b/chatstate/manifest.ini @@ -1,7 +1,7 @@ [info] name: Chatstate in roster short_name: chatstate -version: 0.1 +version: 0.2 description: Chat State Notifications in roster. Font color of the contact varies depending on the chat state. The plugin does not work if you use custom font color for contacts in roster.