add a new event to allow not playing sound when chat window is focused. fixes #2907

This commit is contained in:
Yann Leboulanger 2008-01-27 20:15:17 +00:00
parent 4c219e4f57
commit 7d5602c4b1
7 changed files with 43 additions and 8 deletions

View File

@ -1,5 +1,5 @@
AC_INIT([Gajim - A Jabber Instant Messager], AC_INIT([Gajim - A Jabber Instant Messager],
[0.11.4.1-svn],[http://trac.gajim.org/],[gajim]) [0.11.4.2-svn],[http://trac.gajim.org/],[gajim])
AC_PREREQ([2.59]) AC_PREREQ([2.59])
AM_INIT_AUTOMAKE([1.8]) AM_INIT_AUTOMAKE([1.8])
AC_CONFIG_HEADER(config.h) AC_CONFIG_HEADER(config.h)

View File

@ -408,7 +408,8 @@ class Config:
soundevents_default = { soundevents_default = {
'first_message_received': [ True, '../data/sounds/message1.wav' ], 'first_message_received': [ True, '../data/sounds/message1.wav' ],
'next_message_received': [ True, '../data/sounds/message2.wav' ], 'next_message_received_focused': [ True, '../data/sounds/message2.wav' ],
'next_message_received_unfocused': [ True, '../data/sounds/message2.wav' ],
'contact_connected': [ True, '../data/sounds/connected.wav' ], 'contact_connected': [ True, '../data/sounds/connected.wav' ],
'contact_disconnected': [ True, '../data/sounds/disconnected.wav' ], 'contact_disconnected': [ True, '../data/sounds/disconnected.wav' ],
'message_sent': [ True, '../data/sounds/sent.wav' ], 'message_sent': [ True, '../data/sounds/sent.wav' ],

View File

@ -2,7 +2,7 @@ docdir = '../'
datadir = '../' datadir = '../'
version = '0.11.4.1-svn' version = '0.11.4.2-svn'
import sys, os.path import sys, os.path
for base in ('.', 'common'): for base in ('.', 'common'):

View File

@ -176,6 +176,8 @@ class OptionsParser:
self.update_config_to_01121() self.update_config_to_01121()
if old < [0, 11, 4, 1] and new >= [0, 11, 4, 1]: if old < [0, 11, 4, 1] and new >= [0, 11, 4, 1]:
self.update_config_to_01141() self.update_config_to_01141()
if old < [0, 11, 4, 2] and new >= [0, 11, 4, 2]:
self.update_config_to_01142()
gajim.logger.init_vars() gajim.logger.init_vars()
gajim.config.set('version', new_version) gajim.config.set('version', new_version)
@ -526,3 +528,18 @@ class OptionsParser:
con.close() con.close()
gajim.config.set('version', '0.11.4.1') gajim.config.set('version', '0.11.4.1')
def update_config_to_01142(self):
'''next_message_received sound event is splittedin 2 events'''
gajim.config.add_per('soundevents', 'next_message_received_focused')
gajim.config.add_per('soundevents', 'next_message_received_unfocused')
if gajim.config.get_per('soundevents', 'next_message_received'):
enabled = gajim.config.get_per('soundevents', 'next_message_received',
'enabled')
path = gajim.config.get_per('soundevents', 'next_message_received',
'path')
gajim.config.del_per('soundevents', 'next_message_received')
gajim.config.set_per('soundevents', 'next_message_received_focused',
'enabled', enabled)
gajim.config.set_per('soundevents', 'next_message_received_focused',
'path', path)
gajim.config.set('version', '0.11.1.2')

View File

@ -1089,12 +1089,15 @@ class PreferencesWindow:
def fill_sound_treeview(self): def fill_sound_treeview(self):
model = self.sound_tree.get_model() model = self.sound_tree.get_model()
model.clear() model.clear()
model.set_sort_column_id(1, gtk.SORT_ASCENDING)
# NOTE: sounds_ui_names MUST have all items of # NOTE: sounds_ui_names MUST have all items of
# sounds = gajim.config.get_per('soundevents') as keys # sounds = gajim.config.get_per('soundevents') as keys
sounds_dict = { sounds_dict = {
'first_message_received': _('First Message Received'), 'first_message_received': _('First Message Received'),
'next_message_received': _('Next Message Received'), 'next_message_received_focused': _('Next Message Received Focused'),
'next_message_received_unfocused':
_('Next Message Received Unfocused'),
'contact_connected': _('Contact Connected'), 'contact_connected': _('Contact Connected'),
'contact_disconnected': _('Contact Disconnected'), 'contact_disconnected': _('Contact Disconnected'),
'message_sent': _('Message Sent'), 'message_sent': _('Message Sent'),

View File

@ -847,8 +847,14 @@ class Interface:
msg = message msg = message
if subject: if subject:
msg = _('Subject: %s') % subject + '\n' + msg msg = _('Subject: %s') % subject + '\n' + msg
focused = False
if chat_control:
parent_win = chat_control.parent_win
if chat_control == parent_win.get_active_control() and \
parent_win.window.has_focus:
focused = True
notify.notify('new_message', jid_of_control, account, [msg_type, notify.notify('new_message', jid_of_control, account, [msg_type,
first, nickname, msg], advanced_notif_num) first, nickname, msg, focused], advanced_notif_num)
if self.remote_ctrl: if self.remote_ctrl:
self.remote_ctrl.raise_signal('NewMessage', (account, array)) self.remote_ctrl.raise_signal('NewMessage', (account, array))

View File

@ -175,14 +175,20 @@ def notify(event, jid, account, parameters, advanced_notif_num = None):
else: else:
# We don't want message preview, do_preview = False # We don't want message preview, do_preview = False
message = '' message = ''
focused = parameters[4]
if helpers.allow_showing_notification(account, 'notify_on_new_message', if helpers.allow_showing_notification(account, 'notify_on_new_message',
advanced_notif_num, is_first_message): advanced_notif_num, is_first_message):
do_popup = True do_popup = True
if is_first_message and helpers.allow_sound_notification( if is_first_message and helpers.allow_sound_notification(
'first_message_received', advanced_notif_num): 'first_message_received', advanced_notif_num):
do_sound = True do_sound = True
elif not is_first_message and helpers.allow_sound_notification( elif not is_first_message and focused and \
'next_message_received', advanced_notif_num): helpers.allow_sound_notification('next_message_received_focused',
advanced_notif_num):
do_sound = True
elif not is_first_message and not focused and \
helpers.allow_sound_notification('next_message_received_unfocused',
advanced_notif_num):
do_sound = True do_sound = True
else: else:
print '*Event not implemeted yet*' print '*Event not implemeted yet*'
@ -285,8 +291,10 @@ def notify(event, jid, account, parameters, advanced_notif_num = None):
pass # do not set snd_event pass # do not set snd_event
elif is_first_message: elif is_first_message:
snd_event = 'first_message_received' snd_event = 'first_message_received'
elif focused:
snd_event = 'next_message_received_focused'
else: else:
snd_event = 'next_message_received' snd_event = 'next_message_received_unfocused'
elif event in ('contact_connected', 'contact_disconnected'): elif event in ('contact_connected', 'contact_disconnected'):
snd_event = event snd_event = event
if snd_file: if snd_file: