diff --git a/length_notifier/config_dialog.ui b/length_notifier/config_dialog.ui
index 7190f86..cca3ff1 100644
--- a/length_notifier/config_dialog.ui
+++ b/length_notifier/config_dialog.ui
@@ -4,6 +4,9 @@
-
- 1
- 2
-
-
-
-
- Show Character Count
- True
- True
- False
- Adds a character counter to the message input
- start
- True
-
-
1
1
-
+
+ True
+ False
+ end
+ XMPP Addresses
+
+
+
+ 0
+ 2
+
+
+
+
+ True
+ True
+ Restrict this plugin to certain contacts, e.g. to one microblogging bot (use comma without space as separator)
+ start
+ user@example.org
+
+
+ 1
+ 2
+
diff --git a/length_notifier/length_notifier.py b/length_notifier/length_notifier.py
index 649af5e..729c884 100644
--- a/length_notifier/length_notifier.py
+++ b/length_notifier/length_notifier.py
@@ -48,7 +48,6 @@ class LengthNotifierPlugin(GajimPlugin):
self.config_default_values = {
'MESSAGE_WARNING_LENGTH' : (140, 'Message length at which notification is invoked.'),
- 'CHAR_COUNTER': (True, 'Show character count'),
'WARNING_COLOR' : ('#F0DB3E', 'Background color of text entry field in chat window when notification is invoked.'),
'JIDS' : ([], 'JabberIDs that plugin should be used with (eg. restrict only to one microblogging bot). If empty plugin is used with every JID. [not implemented]')
}
@@ -57,13 +56,15 @@ class LengthNotifierPlugin(GajimPlugin):
def textview_length_warning(self, tb, chat_control):
tv = chat_control.msg_textview
d = chat_control.length_notifier_plugin_data
+ counter = d['counter']
if not tv.has_text():
- self.counter.set_text('0')
+ counter.set_text('0')
if tv.has_text():
t = tb.get_text(tb.get_start_iter(), tb.get_end_iter(), True)
len_t = len(t)
- self.counter.set_text(str(len_t))
- if len_t > self.config['MESSAGE_WARNING_LENGTH']:
+ counter.set_text(str(len_t))
+ warning_length = self.config['MESSAGE_WARNING_LENGTH']
+ if len_t > warning_length and warning_length != 0:
if not d['prev_color']:
#FIXME: That doesn't work
context = tv.get_style_context()
@@ -84,19 +85,27 @@ class LengthNotifierPlugin(GajimPlugin):
def connect_with_chat_control(self, chat_control):
jid = chat_control.contact.jid
if self.jid_is_ok(jid):
- self._create_counter(chat_control)
+ actions_hbox = chat_control.xml.get_object('hbox')
+ counter = Gtk.Label()
+ counter.set_tooltip_text(_('Number of typed characters'))
+ counter.get_style_context().add_class('dim-label')
+ counter.show()
+ actions_hbox.pack_start(counter, False, False, 0)
+
d = {'prev_color' : None}
tv = chat_control.msg_textview
tb = tv.get_buffer()
h_id = tb.connect('changed', self.textview_length_warning,
chat_control)
d['h_id'] = h_id
+ d['counter'] = counter
if tv.has_text():
t = tb.get_text(tb.get_start_iter(), tb.get_end_iter(), True)
len_t = len(t)
- self.counter.set_text(str(len_t))
- if len_t > self.config['MESSAGE_WARNING_LENGTH']:
+ counter.set_text(str(len_t))
+ warning_length = self.config['MESSAGE_WARNING_LENGTH']
+ if len_t > warning_length and warning_length != 0:
context = tv.get_style_context()
d['prev_color'] = context.get_background_color(
Gtk.StateFlags.NORMAL)
@@ -104,7 +113,7 @@ class LengthNotifierPlugin(GajimPlugin):
Gdk.RGBA.parse(color, self.config['WARNING_COLOR'])
tv.override_background_color(Gtk.StateType.NORMAL, color)
else:
- self.counter.set_text('0')
+ counter.set_text('0')
chat_control.length_notifier_plugin_data = d
return True
@@ -114,17 +123,17 @@ class LengthNotifierPlugin(GajimPlugin):
@log_calls('LengthNotifierPlugin')
def disconnect_from_chat_control(self, chat_control):
try:
- actions_hbox = chat_control.xml.get_object('hbox')
- actions_hbox.remove(self.counter)
d = chat_control.length_notifier_plugin_data
+ actions_hbox = chat_control.xml.get_object('hbox')
+ actions_hbox.remove(d['counter'])
+
tv = chat_control.msg_textview
tv.get_buffer().disconnect(d['h_id'])
if d['prev_color']:
tv.override_background_color(Gtk.StateType.NORMAL,
d['prev_color'])
- except AttributeError as error:
+ except AttributeError:
pass
- #log.debug('Length Notifier Plugin was (probably) never connected with this chat window.\n Error: %s' % (error))
@log_calls('LengthNotifierPlugin')
def jid_is_ok(self, jid):
@@ -133,21 +142,6 @@ class LengthNotifierPlugin(GajimPlugin):
return False
- def _create_counter(self, chat_control):
- actions_hbox = chat_control.xml.get_object('hbox')
- self.counter = Gtk.Label()
- self.counter.set_tooltip_text(_('Number of typed characters'))
- self.counter.get_style_context().add_class('dim-label')
- self.counter.set_no_show_all(True)
- actions_hbox.pack_start(self.counter, False, False, 0)
- self.toggle_counter()
-
- def toggle_counter(self):
- if self.config['CHAR_COUNTER']:
- self.counter.show()
- else:
- self.counter.hide()
-
class LengthNotifierPluginConfigDialog(GajimPluginConfigDialog):
def init(self):
@@ -164,7 +158,6 @@ class LengthNotifierPluginConfigDialog(GajimPluginConfigDialog):
'message_length_spinbutton')
self.message_length_spinbutton.get_adjustment().configure(140, 0, 500,
1, 10, 0)
- self.char_counter = self.xml.get_object('char_counter')
self.notification_colorbutton = self.xml.get_object(
'notification_colorbutton')
self.jids_entry = self.xml.get_object('jids_entry')
@@ -175,7 +168,6 @@ class LengthNotifierPluginConfigDialog(GajimPluginConfigDialog):
self.message_length_spinbutton.set_value(self.plugin.config[
'MESSAGE_WARNING_LENGTH'])
color = Gdk.Color.parse(self.plugin.config['WARNING_COLOR'])[1]
- self.char_counter.set_active(self.plugin.config['CHAR_COUNTER'])
self.notification_colorbutton.set_color(color)
#self.jids_entry.set_text(self.plugin.config['JIDS'])
self.jids_entry.set_text(','.join(self.plugin.config['JIDS']))
@@ -184,10 +176,6 @@ class LengthNotifierPluginConfigDialog(GajimPluginConfigDialog):
def on_message_length_spinbutton_value_changed(self, spinbutton):
self.plugin.config['MESSAGE_WARNING_LENGTH'] = spinbutton.get_value()
- def _on_char_counter_toggled(self, checkbutton):
- self.plugin.config['CHAR_COUNTER'] = checkbutton.get_active()
- self.plugin.toggle_counter()
-
@log_calls('LengthNotifierPluginConfigDialog')
def on_notification_colorbutton_color_set(self, colorbutton):
self.plugin.config['WARNING_COLOR'] = colorbutton.get_color().\