messenger fixes, refactoring (history)
This commit is contained in:
parent
6ebafbda44
commit
ad351030d9
9 changed files with 150 additions and 135 deletions
|
@ -141,6 +141,8 @@ class App:
|
||||||
|
|
||||||
def _load_app_styles(self):
|
def _load_app_styles(self):
|
||||||
# application color scheme
|
# application color scheme
|
||||||
|
if self._settings['theme'] == 'dark':
|
||||||
|
return
|
||||||
for theme in self._settings.built_in_themes().keys():
|
for theme in self._settings.built_in_themes().keys():
|
||||||
if self._settings['theme'] == theme:
|
if self._settings['theme'] == theme:
|
||||||
with open(curr_directory(__file__) + self._settings.built_in_themes()[theme]) as fl:
|
with open(curr_directory(__file__) + self._settings.built_in_themes()[theme]) as fl:
|
||||||
|
@ -294,17 +296,17 @@ class App:
|
||||||
self._friend_factory = FriendFactory(self._profile_manager, self._settings, self._tox, db, items_factory)
|
self._friend_factory = FriendFactory(self._profile_manager, self._settings, self._tox, db, items_factory)
|
||||||
self._contacts_provider = ContactProvider(self._tox, self._friend_factory)
|
self._contacts_provider = ContactProvider(self._tox, self._friend_factory)
|
||||||
widgets_factory = WidgetsFactory(self._settings, profile, self._contacts_manager, self._file_transfer_handler,
|
widgets_factory = WidgetsFactory(self._settings, profile, self._contacts_manager, self._file_transfer_handler,
|
||||||
self._smiley_loader, self._plugin_loader, self._toxes)
|
self._smiley_loader, self._plugin_loader, self._toxes, self._version)
|
||||||
self._contacts_manager = ContactsManager(self._tox, self._settings, self._ms, self._profile_manager,
|
self._contacts_manager = ContactsManager(self._tox, self._settings, self._ms, self._profile_manager,
|
||||||
self._contacts_provider, db)
|
self._contacts_provider, db)
|
||||||
self._messenger = Messenger(self._tox, self._plugin_loader, self._ms, self._contacts_manager,
|
self._messenger = Messenger(self._tox, self._plugin_loader, self._ms, self._contacts_manager,
|
||||||
self._contacts_provider)
|
self._contacts_provider, items_factory)
|
||||||
self._tray = tray.init_tray(profile, self._settings, self._ms)
|
self._tray = tray.init_tray(profile, self._settings, self._ms)
|
||||||
self._ms.set_dependencies(widgets_factory, self._tray, self._contacts_manager, self._messenger)
|
self._ms.set_dependencies(widgets_factory, self._tray, self._contacts_manager, self._messenger, profile)
|
||||||
self._calls_manager = CallsManager(self._tox.AV, self._settings)
|
self._calls_manager = CallsManager(self._tox.AV, self._settings)
|
||||||
self._file_transfer_handler = FileTransfersHandler(self._tox, self._settings, self._contacts_provider)
|
self._file_transfer_handler = FileTransfersHandler(self._tox, self._settings, self._contacts_provider)
|
||||||
self._tray.show()
|
|
||||||
|
|
||||||
|
self._tray.show()
|
||||||
self._ms.show()
|
self._ms.show()
|
||||||
|
|
||||||
# callbacks initialization
|
# callbacks initialization
|
||||||
|
|
|
@ -1,7 +1,6 @@
|
||||||
import util.util as util
|
import util.util as util
|
||||||
import util.ui as util_ui
|
import util.ui as util_ui
|
||||||
from contacts.friend import Friend
|
from contacts.friend import Friend
|
||||||
import os
|
|
||||||
from PyQt5 import QtCore, QtGui
|
from PyQt5 import QtCore, QtGui
|
||||||
from messenger.messages import *
|
from messenger.messages import *
|
||||||
from wrapper.toxcore_enums_and_consts import *
|
from wrapper.toxcore_enums_and_consts import *
|
||||||
|
@ -9,10 +8,10 @@ from network.tox_dns import tox_dns
|
||||||
from history.history_loader import HistoryLoader
|
from history.history_loader import HistoryLoader
|
||||||
|
|
||||||
|
|
||||||
# TODO: move messaging and typing notifications to other class
|
|
||||||
|
|
||||||
|
|
||||||
class ContactsManager:
|
class ContactsManager:
|
||||||
|
"""
|
||||||
|
Represents contacts list.
|
||||||
|
"""
|
||||||
|
|
||||||
def __init__(self, tox, settings, screen, profile_manager, contact_provider, db):
|
def __init__(self, tox, settings, screen, profile_manager, contact_provider, db):
|
||||||
self._tox = tox
|
self._tox = tox
|
||||||
|
@ -134,12 +133,11 @@ class ContactsManager:
|
||||||
# self._screen.call_finished()
|
# self._screen.call_finished()
|
||||||
else:
|
else:
|
||||||
friend = self.get_curr_contact()
|
friend = self.get_curr_contact()
|
||||||
|
# TODO: to separate method
|
||||||
self._screen.account_name.setText(friend.name)
|
self._screen.account_name.setText(friend.name)
|
||||||
self._screen.account_status.setText(friend.status_message)
|
self._screen.account_status.setText(friend.status_message)
|
||||||
self._screen.account_status.setToolTip(friend.get_full_status())
|
self._screen.account_status.setToolTip(friend.get_full_status())
|
||||||
avatar_path = friend.get_avatar_path()
|
avatar_path = friend.get_avatar_path()
|
||||||
os.chdir(os.path.dirname(avatar_path))
|
|
||||||
pixmap = QtGui.QPixmap(avatar_path)
|
pixmap = QtGui.QPixmap(avatar_path)
|
||||||
self._screen.account_avatar.setPixmap(pixmap.scaled(64, 64, QtCore.Qt.KeepAspectRatio,
|
self._screen.account_avatar.setPixmap(pixmap.scaled(64, 64, QtCore.Qt.KeepAspectRatio,
|
||||||
QtCore.Qt.SmoothTransformation))
|
QtCore.Qt.SmoothTransformation))
|
||||||
|
@ -171,6 +169,7 @@ class ContactsManager:
|
||||||
:param sorting: 0 - no sort, 1 - online only, 2 - online first, 4 - by name
|
:param sorting: 0 - no sort, 1 - online only, 2 - online first, 4 - by name
|
||||||
:param filter_str: show contacts which name contains this substring
|
:param filter_str: show contacts which name contains this substring
|
||||||
"""
|
"""
|
||||||
|
# TODO: simplify?
|
||||||
filter_str = filter_str.lower()
|
filter_str = filter_str.lower()
|
||||||
number = self.get_active_number()
|
number = self.get_active_number()
|
||||||
is_friend = self._is_active_a_friend()
|
is_friend = self._is_active_a_friend()
|
||||||
|
@ -196,16 +195,16 @@ class ContactsManager:
|
||||||
part1 = sorted(part1, key=lambda x: x.number)
|
part1 = sorted(part1, key=lambda x: x.number)
|
||||||
part2 = sorted(part2, key=lambda x: x.number)
|
part2 = sorted(part2, key=lambda x: x.number)
|
||||||
self._contacts = part1 + part2
|
self._contacts = part1 + part2
|
||||||
self._screen.friends_list.clear()
|
# self._screen.friends_list.clear()
|
||||||
for contact in self._contacts:
|
# for contact in self._contacts:
|
||||||
contact.set_widget(self.create_friend_item())
|
# contact.set_widget(self.create_friend_item())
|
||||||
for index, friend in enumerate(self._contacts):
|
for index, friend in enumerate(self._contacts):
|
||||||
friend.visibility = (friend.status is not None or not (sorting & 1)) and (filter_str in friend.name.lower())
|
friend.visibility = (friend.status is not None or not (sorting & 1)) and (filter_str in friend.name.lower())
|
||||||
friend.visibility = friend.visibility or friend.messages or friend.actions
|
friend.visibility = friend.visibility or friend.messages or friend.actions
|
||||||
# if friend.visibility:
|
if friend.visibility:
|
||||||
# self._screen.friends_list.item(index).setSizeHint(QtCore.QSize(250, self._friend_item_height))
|
self._screen.friends_list.item(index).setSizeHint(QtCore.QSize(250, self._friend_item_height))
|
||||||
# else:
|
else:
|
||||||
# self._screen.friends_list.item(index).setSizeHint(QtCore.QSize(250, 0))
|
self._screen.friends_list.item(index).setSizeHint(QtCore.QSize(250, 0))
|
||||||
self._sorting, self._filter_string = sorting, filter_str
|
self._sorting, self._filter_string = sorting, filter_str
|
||||||
self._settings['sorting'] = self._sorting
|
self._settings['sorting'] = self._sorting
|
||||||
self._settings.save()
|
self._settings.save()
|
||||||
|
@ -217,13 +216,6 @@ class ContactsManager:
|
||||||
"""
|
"""
|
||||||
self.filtration_and_sorting(self._sorting, self._filter_string)
|
self.filtration_and_sorting(self._sorting, self._filter_string)
|
||||||
|
|
||||||
def _create_friend_item(self):
|
|
||||||
"""
|
|
||||||
Method-factory
|
|
||||||
:return: new widget for friend instance
|
|
||||||
"""
|
|
||||||
return self._factory.friend_item()
|
|
||||||
|
|
||||||
# -----------------------------------------------------------------------------------------------------------------
|
# -----------------------------------------------------------------------------------------------------------------
|
||||||
# Friend getters
|
# Friend getters
|
||||||
# -----------------------------------------------------------------------------------------------------------------
|
# -----------------------------------------------------------------------------------------------------------------
|
||||||
|
@ -233,7 +225,7 @@ class ContactsManager:
|
||||||
|
|
||||||
def get_last_message(self):
|
def get_last_message(self):
|
||||||
if self._active_contact + 1:
|
if self._active_contact + 1:
|
||||||
return self.get_current_contact().get_last_message_text()
|
return self.get_curr_contact().get_last_message_text()
|
||||||
else:
|
else:
|
||||||
return ''
|
return ''
|
||||||
|
|
||||||
|
@ -241,12 +233,13 @@ class ContactsManager:
|
||||||
return self.get_curr_contact().number if self._active_contact + 1 else -1
|
return self.get_curr_contact().number if self._active_contact + 1 else -1
|
||||||
|
|
||||||
def get_active_name(self):
|
def get_active_name(self):
|
||||||
return self.get_current_contact().name if self._active_contact + 1 else ''
|
return self.get_curr_contact().name if self._active_contact + 1 else ''
|
||||||
|
|
||||||
def is_active_online(self):
|
def is_active_online(self):
|
||||||
return self._active_contact + 1 and self.get_current_contact().status is not None
|
return self._active_contact + 1 and self.get_curr_contact().status is not None
|
||||||
|
|
||||||
def new_name(self, number, name):
|
def new_name(self, number, name):
|
||||||
|
# TODO: move to somewhere else?
|
||||||
friend = self.get_friend_by_number(number)
|
friend = self.get_friend_by_number(number)
|
||||||
tmp = friend.name
|
tmp = friend.name
|
||||||
friend.set_name(name)
|
friend.set_name(name)
|
||||||
|
@ -254,7 +247,7 @@ class ContactsManager:
|
||||||
if friend.name == name and tmp != name:
|
if friend.name == name and tmp != name:
|
||||||
message = util_ui.tr('User {} is now known as {}')
|
message = util_ui.tr('User {} is now known as {}')
|
||||||
message = message.format(tmp, name)
|
message = message.format(tmp, name)
|
||||||
friend.append_message(InfoMessage(message, time.time()))
|
friend.append_message(InfoMessage(0, message, util.get_unix_time()))
|
||||||
friend.actions = True
|
friend.actions = True
|
||||||
if number == self.get_active_number():
|
if number == self.get_active_number():
|
||||||
self.create_message_item(message, time.time(), '', MESSAGE_TYPE['INFO_MESSAGE'])
|
self.create_message_item(message, time.time(), '', MESSAGE_TYPE['INFO_MESSAGE'])
|
||||||
|
@ -293,12 +286,16 @@ class ContactsManager:
|
||||||
except:
|
except:
|
||||||
pass
|
pass
|
||||||
self._settings.save()
|
self._settings.save()
|
||||||
if num == self.get_active_number() and self.is_active_a_friend():
|
# if num == self.get_active_number() and self.is_active_a_friend():
|
||||||
self.update()
|
# self.update()
|
||||||
|
|
||||||
def friend_public_key(self, num):
|
def friend_public_key(self, num):
|
||||||
return self._contacts[num].tox_id
|
return self._contacts[num].tox_id
|
||||||
|
|
||||||
|
def export_history(self, num, as_text):
|
||||||
|
contact = self._contacts[num]
|
||||||
|
return self._history.export_history(contact, as_text)
|
||||||
|
|
||||||
def delete_friend(self, num):
|
def delete_friend(self, num):
|
||||||
"""
|
"""
|
||||||
Removes friend from contact list
|
Removes friend from contact list
|
||||||
|
@ -313,17 +310,12 @@ class ContactsManager:
|
||||||
if friend.tox_id in self._settings['notes']:
|
if friend.tox_id in self._settings['notes']:
|
||||||
del self._settings['notes'][friend.tox_id]
|
del self._settings['notes'][friend.tox_id]
|
||||||
self._settings.save()
|
self._settings.save()
|
||||||
self.clear_history(num)
|
self._history.delete_history(friend)
|
||||||
if self._history.friend_exists_in_db(friend.tox_id):
|
|
||||||
self._history.delete_friend_from_db(friend.tox_id)
|
|
||||||
self._tox.friend_delete(friend.number)
|
self._tox.friend_delete(friend.number)
|
||||||
del self._contacts[num]
|
del self._contacts[num]
|
||||||
self._screen.friends_list.takeItem(num)
|
self._screen.friends_list.takeItem(num)
|
||||||
if num == self._active_contact: # active friend was deleted
|
if num == self._active_contact: # active friend was deleted
|
||||||
if not len(self._contacts): # last friend was deleted
|
self.set_active(0 if len(self._contacts) else -1)
|
||||||
self.set_active(-1)
|
|
||||||
else:
|
|
||||||
self.set_active(0)
|
|
||||||
data = self._tox.get_savedata()
|
data = self._tox.get_savedata()
|
||||||
self._profile_manager.save_profile(data)
|
self._profile_manager.save_profile(data)
|
||||||
|
|
||||||
|
@ -387,13 +379,9 @@ class ContactsManager:
|
||||||
text = util_ui.tr('Friend added without sending friend request')
|
text = util_ui.tr('Friend added without sending friend request')
|
||||||
util_ui.message_box(text, title)
|
util_ui.message_box(text, title)
|
||||||
else:
|
else:
|
||||||
result = self._tox.friend_add(tox_id, message.encode('utf-8'))
|
self._tox.friend_add(tox_id, message.encode('utf-8'))
|
||||||
tox_id = tox_id[:TOX_PUBLIC_KEY_SIZE * 2]
|
tox_id = tox_id[:TOX_PUBLIC_KEY_SIZE * 2]
|
||||||
item = self.create_friend_item()
|
friend = self._contact_provider.get_friend_by_public_key(tox_id)
|
||||||
if not self._history.friend_exists_in_db(tox_id):
|
|
||||||
self._history.add_friend_to_db(tox_id)
|
|
||||||
message_getter = self._history.messages_getter(tox_id)
|
|
||||||
friend = Friend(message_getter, result, tox_id, '', item, tox_id)
|
|
||||||
self._contacts.append(friend)
|
self._contacts.append(friend)
|
||||||
self.save_profile()
|
self.save_profile()
|
||||||
return True
|
return True
|
||||||
|
@ -420,7 +408,7 @@ class ContactsManager:
|
||||||
util.log('Accept friend request failed! ' + str(ex))
|
util.log('Accept friend request failed! ' + str(ex))
|
||||||
|
|
||||||
def can_send_typing_notification(self):
|
def can_send_typing_notification(self):
|
||||||
return self._settings['typing_notifications'] and self._active_contact != -1
|
return self._settings['typing_notifications'] and self._active_contact + 1
|
||||||
|
|
||||||
# -----------------------------------------------------------------------------------------------------------------
|
# -----------------------------------------------------------------------------------------------------------------
|
||||||
# Private methods
|
# Private methods
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
from messenger.messages import *
|
from history.history_logs_generators import *
|
||||||
|
|
||||||
# TODO: fix history loading and saving
|
# TODO: fix history loading and saving
|
||||||
|
|
||||||
|
@ -96,65 +96,21 @@ class HistoryLoader:
|
||||||
|
|
||||||
return self._db.messages_getter(friend_public_key)
|
return self._db.messages_getter(friend_public_key)
|
||||||
|
|
||||||
@staticmethod
|
def delete_history(self, friend):
|
||||||
def export_history(friend, as_text=True, _range=None):
|
self.clear_history(friend)
|
||||||
if _range is None:
|
if self._db.friend_exists_in_db(friend.tox_id):
|
||||||
friend.load_all_corr()
|
self._db.delete_friend_from_db(friend.tox_id)
|
||||||
corr = friend.get_corr()
|
|
||||||
elif _range[1] + 1:
|
|
||||||
corr = friend.get_corr()[_range[0]:_range[1] + 1]
|
|
||||||
else:
|
|
||||||
corr = friend.get_corr()[_range[0]:]
|
|
||||||
|
|
||||||
generator = TextHistoryGenerator(corr) if as_text else HtmlHistoryGenerator(corr)
|
@staticmethod
|
||||||
|
def export_history(contact, as_text=True, _range=None):
|
||||||
|
if _range is None:
|
||||||
|
contact.load_all_corr()
|
||||||
|
corr = contact.get_corr()
|
||||||
|
elif _range[1] + 1:
|
||||||
|
corr = contact.get_corr()[_range[0]:_range[1] + 1]
|
||||||
|
else:
|
||||||
|
corr = contact.get_corr()[_range[0]:]
|
||||||
|
|
||||||
|
generator = TextHistoryGenerator(corr, contact.name) if as_text else HtmlHistoryGenerator(corr, contact.name)
|
||||||
|
|
||||||
return generator.generate()
|
return generator.generate()
|
||||||
|
|
||||||
|
|
||||||
class HistoryLogsGenerator:
|
|
||||||
|
|
||||||
def __init__(self, history):
|
|
||||||
self._history = history
|
|
||||||
|
|
||||||
def generate(self):
|
|
||||||
return str()
|
|
||||||
|
|
||||||
|
|
||||||
class HtmlHistoryGenerator(HistoryLogsGenerator):
|
|
||||||
|
|
||||||
def __init__(self, history):
|
|
||||||
super().__init__(history)
|
|
||||||
|
|
||||||
def generate(self):
|
|
||||||
arr = []
|
|
||||||
for message in self._history:
|
|
||||||
if type(message) is TextMessage:
|
|
||||||
data = message.get_data()
|
|
||||||
x = '[{}] <b>{}:</b> {}<br>'
|
|
||||||
arr.append(x.format(convert_time(data[2]) if data[1] != MESSAGE_OWNER['NOT_SENT'] else 'Unsent',
|
|
||||||
friend.name if data[1] == MESSAGE_OWNER['FRIEND'] else self.name,
|
|
||||||
data[0]))
|
|
||||||
s = '<br>'.join(arr)
|
|
||||||
s = '<html><head><meta charset="UTF-8"><title>{}</title></head><body>{}</body></html>'.format(friend.name,
|
|
||||||
s)
|
|
||||||
return s
|
|
||||||
|
|
||||||
|
|
||||||
class TextHistoryGenerator(HistoryLogsGenerator):
|
|
||||||
|
|
||||||
def __init__(self, history):
|
|
||||||
super().__init__(history)
|
|
||||||
|
|
||||||
def generate(self):
|
|
||||||
arr = []
|
|
||||||
for message in self._history:
|
|
||||||
if type(message) is TextMessage:
|
|
||||||
data = message.get_data()
|
|
||||||
x = '[{}] {}: {}\n'
|
|
||||||
arr.append(x.format(convert_time(data[2]) if data[1] != MESSAGE_OWNER['NOT_SENT'] else 'Unsent',
|
|
||||||
friend.name if data[1] == MESSAGE_OWNER['FRIEND'] else self.name,
|
|
||||||
data[0]))
|
|
||||||
s = '\n'.join(arr)
|
|
||||||
|
|
||||||
return s
|
|
||||||
|
|
||||||
|
|
48
toxygen/history/history_logs_generators.py
Normal file
48
toxygen/history/history_logs_generators.py
Normal file
|
@ -0,0 +1,48 @@
|
||||||
|
from messenger.messages import *
|
||||||
|
import util.util as util
|
||||||
|
|
||||||
|
|
||||||
|
class HistoryLogsGenerator:
|
||||||
|
|
||||||
|
def __init__(self, history, contact_name):
|
||||||
|
self._history = history
|
||||||
|
self._contact_name = contact_name
|
||||||
|
|
||||||
|
def generate(self):
|
||||||
|
return str()
|
||||||
|
|
||||||
|
@staticmethod
|
||||||
|
def _get_message_time(message):
|
||||||
|
return util.convert_time(message.time) if message.author.type != MESSAGE_AUTHOR['NOT_SENT'] else 'Unsent'
|
||||||
|
|
||||||
|
|
||||||
|
class HtmlHistoryGenerator(HistoryLogsGenerator):
|
||||||
|
|
||||||
|
def __init__(self, history, contact_name):
|
||||||
|
super().__init__(history, contact_name)
|
||||||
|
|
||||||
|
def generate(self):
|
||||||
|
arr = []
|
||||||
|
for message in self._history:
|
||||||
|
if type(message) is TextMessage:
|
||||||
|
x = '[{}] <b>{}:</b> {}<br>'
|
||||||
|
arr.append(x.format(self._get_message_time(message), message.author.name, message.text))
|
||||||
|
s = '<br>'.join(arr)
|
||||||
|
html = '<html><head><meta charset="UTF-8"><title>{}</title></head><body>{}</body></html>'
|
||||||
|
|
||||||
|
return html.format(self._contact_name, s)
|
||||||
|
|
||||||
|
|
||||||
|
class TextHistoryGenerator(HistoryLogsGenerator):
|
||||||
|
|
||||||
|
def __init__(self, history, contact_name):
|
||||||
|
super().__init__(history, contact_name)
|
||||||
|
|
||||||
|
def generate(self):
|
||||||
|
arr = [self._contact_name]
|
||||||
|
for message in self._history:
|
||||||
|
if type(message) is TextMessage:
|
||||||
|
x = '[{}] {}: {}\n'
|
||||||
|
arr.append(x.format(self._get_message_time(message), message.author.name, message.text))
|
||||||
|
|
||||||
|
return '\n'.join(arr)
|
|
@ -38,6 +38,11 @@ class Message:
|
||||||
|
|
||||||
author = property(get_author)
|
author = property(get_author)
|
||||||
|
|
||||||
|
def get_time(self):
|
||||||
|
return self._time
|
||||||
|
|
||||||
|
time = property(get_time)
|
||||||
|
|
||||||
def get_message_id(self):
|
def get_message_id(self):
|
||||||
return self._message_id
|
return self._message_id
|
||||||
|
|
||||||
|
@ -70,6 +75,11 @@ class TextMessage(Message):
|
||||||
super().__init__(id, message_type, owner, time)
|
super().__init__(id, message_type, owner, time)
|
||||||
self._message = message
|
self._message = message
|
||||||
|
|
||||||
|
def get_text(self):
|
||||||
|
return self._message
|
||||||
|
|
||||||
|
text = property(get_text)
|
||||||
|
|
||||||
def get_data(self):
|
def get_data(self):
|
||||||
return self._message, self._owner, self._time, self._type
|
return self._message, self._owner, self._time, self._type
|
||||||
|
|
||||||
|
|
|
@ -5,19 +5,21 @@ from messenger.messages import *
|
||||||
|
|
||||||
class Messenger(util.ToxSave):
|
class Messenger(util.ToxSave):
|
||||||
|
|
||||||
def __init__(self, tox, plugin_loader, screen, contacts_manager, contacts_provider):
|
def __init__(self, tox, plugin_loader, screen, contacts_manager, contacts_provider, items_factory):
|
||||||
super().__init__(tox)
|
super().__init__(tox)
|
||||||
self._plugin_loader = plugin_loader
|
self._plugin_loader = plugin_loader
|
||||||
self._screen = screen
|
self._screen = screen
|
||||||
self._contacts_manager = contacts_manager
|
self._contacts_manager = contacts_manager
|
||||||
self._contacts_provider = contacts_provider
|
self._contacts_provider = contacts_provider
|
||||||
|
self._items_factory = items_factory
|
||||||
|
|
||||||
# -----------------------------------------------------------------------------------------------------------------
|
# -----------------------------------------------------------------------------------------------------------------
|
||||||
# Private methods
|
# Private methods
|
||||||
# -----------------------------------------------------------------------------------------------------------------
|
# -----------------------------------------------------------------------------------------------------------------
|
||||||
|
|
||||||
def _create_message_item(self):
|
def _create_message_item(self, text_message):
|
||||||
pass
|
# pixmap = self._contacts_manager.get_curr_contact().get_pixmap()
|
||||||
|
self._items_factory.message_item(text_message)
|
||||||
|
|
||||||
# -----------------------------------------------------------------------------------------------------------------
|
# -----------------------------------------------------------------------------------------------------------------
|
||||||
# Messaging
|
# Messaging
|
||||||
|
@ -66,17 +68,20 @@ class Messenger(util.ToxSave):
|
||||||
else:
|
else:
|
||||||
message_type = TOX_MESSAGE_TYPE['NORMAL']
|
message_type = TOX_MESSAGE_TYPE['NORMAL']
|
||||||
friend = self.get_friend_by_number(friend_number)
|
friend = self.get_friend_by_number(friend_number)
|
||||||
friend.inc_receipts()
|
messages = self._split_message(text.encode('utf-8'))
|
||||||
if friend.status is not None:
|
t = util.get_unix_time()
|
||||||
messages = self._split_message(text.encode('utf-8'))
|
for message in messages:
|
||||||
t = util.get_unix_time()
|
if friend.status is not None:
|
||||||
for message in messages:
|
|
||||||
message_id = self._tox.friend_send_message(friend_number, message_type, message)
|
message_id = self._tox.friend_send_message(friend_number, message_type, message)
|
||||||
friend.append_message(TextMessage(message_id, text, MESSAGE_AUTHOR['NOT_SENT'], t, message_type))
|
friend.inc_receipts()
|
||||||
if self._contacts_manager.is_friend_active(friend_number):
|
else:
|
||||||
self.create_message_item(text, t, MESSAGE_AUTHOR['NOT_SENT'], message_type)
|
message_id = 0
|
||||||
self._screen.messageEdit.clear()
|
message = TextMessage(message_id, text, MESSAGE_AUTHOR['NOT_SENT'], t, message_type)
|
||||||
self._screen.messages.scrollToBottom()
|
friend.append_message(message)
|
||||||
|
if self._contacts_manager.is_friend_active(friend_number):
|
||||||
|
self._create_message_item(message)
|
||||||
|
self._screen.messageEdit.clear()
|
||||||
|
self._screen.messages.scrollToBottom()
|
||||||
|
|
||||||
# -----------------------------------------------------------------------------------------------------------------
|
# -----------------------------------------------------------------------------------------------------------------
|
||||||
# Typing notifications
|
# Typing notifications
|
||||||
|
@ -121,6 +126,8 @@ class Messenger(util.ToxSave):
|
||||||
index += size + 1
|
index += size + 1
|
||||||
messages.append(message[:index])
|
messages.append(message[:index])
|
||||||
message = message[index:]
|
message = message[index:]
|
||||||
|
if message:
|
||||||
|
messages.append(message)
|
||||||
|
|
||||||
return messages
|
return messages
|
||||||
|
|
||||||
|
|
|
@ -18,8 +18,8 @@ class ItemsFactory:
|
||||||
self._friends_list.setItemWidget(elem, item)
|
self._friends_list.setItemWidget(elem, item)
|
||||||
return item
|
return item
|
||||||
|
|
||||||
def message_item(self, text, time, name, sent, message_type, append, pixmap):
|
def message_item(self, message, pixmap=None):
|
||||||
item = MessageItem(text, time, name, sent, message_type, self._messages)
|
item = MessageItem(message, self._messages)
|
||||||
if pixmap is not None:
|
if pixmap is not None:
|
||||||
item.set_avatar(pixmap)
|
item.set_avatar(pixmap)
|
||||||
elem = QtWidgets.QListWidgetItem()
|
elem = QtWidgets.QListWidgetItem()
|
||||||
|
|
|
@ -17,13 +17,14 @@ class MainWindow(QtWidgets.QMainWindow):
|
||||||
self._modal_window = None
|
self._modal_window = None
|
||||||
self.setAcceptDrops(True)
|
self.setAcceptDrops(True)
|
||||||
self._saved = False
|
self._saved = False
|
||||||
self.profile = None
|
self._profile = None
|
||||||
self.initUI()
|
self.initUI()
|
||||||
|
|
||||||
def set_dependencies(self, widget_factory, tray, contacts_manager, messenger):
|
def set_dependencies(self, widget_factory, tray, contacts_manager, messenger, profile):
|
||||||
self._widget_factory = widget_factory
|
self._widget_factory = widget_factory
|
||||||
self._tray = tray
|
self._tray = tray
|
||||||
self._contacts_manager = contacts_manager
|
self._contacts_manager = contacts_manager
|
||||||
|
self._profile = profile
|
||||||
self.messageEdit.set_messenger(messenger)
|
self.messageEdit.set_messenger(messenger)
|
||||||
|
|
||||||
def show(self):
|
def show(self):
|
||||||
|
@ -401,17 +402,18 @@ class MainWindow(QtWidgets.QMainWindow):
|
||||||
#self.profile.update()
|
#self.profile.update()
|
||||||
|
|
||||||
def keyPressEvent(self, event):
|
def keyPressEvent(self, event):
|
||||||
if event.key() == QtCore.Qt.Key_Escape and QtWidgets.QSystemTrayIcon.isSystemTrayAvailable():
|
key, modifiers = event.key(), event.modifiers()
|
||||||
|
if key == QtCore.Qt.Key_Escape and QtWidgets.QSystemTrayIcon.isSystemTrayAvailable():
|
||||||
self.hide()
|
self.hide()
|
||||||
elif event.key() == QtCore.Qt.Key_C and event.modifiers() & QtCore.Qt.ControlModifier and self.messages.selectedIndexes():
|
elif key == QtCore.Qt.Key_C and modifiers & QtCore.Qt.ControlModifier and self.messages.selectedIndexes():
|
||||||
rows = list(map(lambda x: self.messages.row(x), self.messages.selectedItems()))
|
rows = list(map(lambda x: self.messages.row(x), self.messages.selectedItems()))
|
||||||
indexes = (rows[0] - self.messages.count(), rows[-1] - self.messages.count())
|
indexes = (rows[0] - self.messages.count(), rows[-1] - self.messages.count())
|
||||||
s = self.profile.export_history(self.profile.active_friend, True, indexes)
|
s = self.profile.export_history(self.profile.active_friend, True, indexes)
|
||||||
clipboard = QtWidgets.QApplication.clipboard()
|
clipboard = QtWidgets.QApplication.clipboard()
|
||||||
clipboard.setText(s)
|
clipboard.setText(s)
|
||||||
elif event.key() == QtCore.Qt.Key_Z and event.modifiers() & QtCore.Qt.ControlModifier and self.messages.selectedIndexes():
|
elif key == QtCore.Qt.Key_Z and modifiers & QtCore.Qt.ControlModifier and self.messages.selectedIndexes():
|
||||||
self.messages.clearSelection()
|
self.messages.clearSelection()
|
||||||
elif event.key() == QtCore.Qt.Key_F and event.modifiers() & QtCore.Qt.ControlModifier:
|
elif key == QtCore.Qt.Key_F and modifiers & QtCore.Qt.ControlModifier:
|
||||||
self.show_search_field()
|
self.show_search_field()
|
||||||
else:
|
else:
|
||||||
super().keyPressEvent(event)
|
super().keyPressEvent(event)
|
||||||
|
@ -421,6 +423,7 @@ class MainWindow(QtWidgets.QMainWindow):
|
||||||
# -----------------------------------------------------------------------------------------------------------------
|
# -----------------------------------------------------------------------------------------------------------------
|
||||||
|
|
||||||
def about_program(self):
|
def about_program(self):
|
||||||
|
# TODO: replace with window
|
||||||
text = util_ui.tr('Toxygen is Tox client written on Python.\nVersion: ')
|
text = util_ui.tr('Toxygen is Tox client written on Python.\nVersion: ')
|
||||||
text += '' + '\nGitHub: https://github.com/toxygen-project/toxygen/'
|
text += '' + '\nGitHub: https://github.com/toxygen-project/toxygen/'
|
||||||
title = util_ui.tr('About')
|
title = util_ui.tr('About')
|
||||||
|
@ -435,7 +438,7 @@ class MainWindow(QtWidgets.QMainWindow):
|
||||||
self._modal_window.show()
|
self._modal_window.show()
|
||||||
|
|
||||||
def add_contact(self, link=''):
|
def add_contact(self, link=''):
|
||||||
self._modal_window = self._widget_factory.create_add_contact_window(link or '')
|
self._modal_window = self._widget_factory.create_add_contact_window(link)
|
||||||
self._modal_window.show()
|
self._modal_window.show()
|
||||||
|
|
||||||
def create_gc(self):
|
def create_gc(self):
|
||||||
|
@ -507,7 +510,7 @@ class MainWindow(QtWidgets.QMainWindow):
|
||||||
|
|
||||||
def send_file(self):
|
def send_file(self):
|
||||||
self.menu.hide()
|
self.menu.hide()
|
||||||
if self._contacts_manager.active_friend + 1 and self._contacts_manager.is_active_a_friend():
|
if self._contacts_manager.is_active_a_friend():
|
||||||
caption = util_ui.tr('Choose file')
|
caption = util_ui.tr('Choose file')
|
||||||
name = util_ui.file_dialog(caption)
|
name = util_ui.file_dialog(caption)
|
||||||
if name[0]:
|
if name[0]:
|
||||||
|
@ -515,8 +518,8 @@ class MainWindow(QtWidgets.QMainWindow):
|
||||||
|
|
||||||
def send_screenshot(self, hide=False):
|
def send_screenshot(self, hide=False):
|
||||||
self.menu.hide()
|
self.menu.hide()
|
||||||
if self._contacts_manager.active_friend + 1 and self._contacts_manager.is_active_a_friend():
|
if self._contacts_manager.is_active_a_friend():
|
||||||
self.sw = ScreenShotWindow(self)
|
self.sw = self._widget_factory.create_screenshot_window(self)
|
||||||
self.sw.show()
|
self.sw.show()
|
||||||
if hide:
|
if hide:
|
||||||
self.hide()
|
self.hide()
|
||||||
|
@ -533,7 +536,7 @@ class MainWindow(QtWidgets.QMainWindow):
|
||||||
|
|
||||||
def send_sticker(self):
|
def send_sticker(self):
|
||||||
self.menu.hide()
|
self.menu.hide()
|
||||||
if self._contacts_manager.active_friend + 1 and self._contacts_manager.is_active_a_friend():
|
if self._contacts_manager.is_active_a_friend():
|
||||||
self.sticker = self._widget_factory.create_sticker_window(self)
|
self.sticker = self._widget_factory.create_sticker_window(self)
|
||||||
self.sticker.setGeometry(QtCore.QRect(self.x() if self._settings['mirror_mode'] else 270 + self.x(),
|
self.sticker.setGeometry(QtCore.QRect(self.x() if self._settings['mirror_mode'] else 270 + self.x(),
|
||||||
self.y() + self.height() - 200,
|
self.y() + self.height() - 200,
|
||||||
|
@ -643,7 +646,7 @@ class MainWindow(QtWidgets.QMainWindow):
|
||||||
self.note.show()
|
self.note.show()
|
||||||
|
|
||||||
def export_history(self, num, as_text=True):
|
def export_history(self, num, as_text=True):
|
||||||
s = self._history_loader.export_history(num, as_text)
|
s = self._contacts_manager.export_history(num, as_text)
|
||||||
extension = 'txt' if as_text else 'html'
|
extension = 'txt' if as_text else 'html'
|
||||||
file_name, _ = util_ui.save_file_dialog(util_ui.tr('Choose file name'), extension)
|
file_name, _ = util_ui.save_file_dialog(util_ui.tr('Choose file name'), extension)
|
||||||
|
|
||||||
|
@ -712,11 +715,11 @@ class MainWindow(QtWidgets.QMainWindow):
|
||||||
if (x < event.x() < x + 32) and (y < event.y() < y + 32):
|
if (x < event.x() < x + 32) and (y < event.y() < y + 32):
|
||||||
self.profile.change_status()
|
self.profile.change_status()
|
||||||
else:
|
else:
|
||||||
super(MainWindow, self).mouseReleaseEvent(event)
|
super().mouseReleaseEvent(event)
|
||||||
|
|
||||||
def show(self):
|
def show(self):
|
||||||
super().show()
|
super().show()
|
||||||
#self._contacts_manager.update()
|
self._contacts_manager.update()
|
||||||
|
|
||||||
def filtering(self):
|
def filtering(self):
|
||||||
ind = self.online_contacts.currentIndex()
|
ind = self.online_contacts.currentIndex()
|
||||||
|
@ -726,7 +729,7 @@ class MainWindow(QtWidgets.QMainWindow):
|
||||||
def show_search_field(self):
|
def show_search_field(self):
|
||||||
if hasattr(self, 'search_field') and self.search_field.isVisible():
|
if hasattr(self, 'search_field') and self.search_field.isVisible():
|
||||||
return
|
return
|
||||||
if self._c4.get_curr_friend() is None:
|
if self._contacts_manager.get_curr_friend() is None:
|
||||||
return
|
return
|
||||||
self.search_field = SearchScreen(self.messages, self.messages.width(), self.messages.parent())
|
self.search_field = SearchScreen(self.messages, self.messages.width(), self.messages.parent())
|
||||||
x, y = self.messages.x(), self.messages.y() + self.messages.height() - 40
|
x, y = self.messages.x(), self.messages.y() + self.messages.height() - 40
|
||||||
|
|
|
@ -5,7 +5,7 @@ from ui.menu import *
|
||||||
class WidgetsFactory:
|
class WidgetsFactory:
|
||||||
|
|
||||||
def __init__(self, settings, profile, contacts_manager, file_transfer_handler, smiley_loader, plugin_loader,
|
def __init__(self, settings, profile, contacts_manager, file_transfer_handler, smiley_loader, plugin_loader,
|
||||||
toxes):
|
toxes, version):
|
||||||
self._settings = settings
|
self._settings = settings
|
||||||
self._profile = profile
|
self._profile = profile
|
||||||
self._contacts_manager = contacts_manager
|
self._contacts_manager = contacts_manager
|
||||||
|
@ -13,6 +13,7 @@ class WidgetsFactory:
|
||||||
self._smiley_loader = smiley_loader
|
self._smiley_loader = smiley_loader
|
||||||
self._plugin_loader = plugin_loader
|
self._plugin_loader = plugin_loader
|
||||||
self._toxes = toxes
|
self._toxes = toxes
|
||||||
|
self._version = version
|
||||||
|
|
||||||
def create_screenshot_window(self, *args):
|
def create_screenshot_window(self, *args):
|
||||||
return ScreenShotWindow(self._file_transfer_handler, *args)
|
return ScreenShotWindow(self._file_transfer_handler, *args)
|
||||||
|
|
Loading…
Reference in a new issue