diff --git a/src/callbacks.py b/src/callbacks.py index 4f19d12..40cc133 100644 --- a/src/callbacks.py +++ b/src/callbacks.py @@ -1,4 +1,5 @@ from PySide import QtCore +from toxcore_enums_and_consts import TOX_USER_CONNECTION_STATUS, TOX_CONNECTION # TODO: add all callbacks (replace test callbacks and use wrappers) @@ -29,10 +30,13 @@ def repaint_widget(widget): return widget.repaint -def self_connection_status(st): +def self_connection_status(st, tox_link): def wrapped(tox, connection, user_data): print 'Connection status: ', str(connection) - st.status = connection + if connection == TOX_CONNECTION['NONE']: + st.status = TOX_USER_CONNECTION_STATUS['OFFLINE'] + else: + st.status = int(tox_link.self_get_status()) invoke_in_main_thread(repaint_widget(st)) return wrapped @@ -53,4 +57,4 @@ def init_callbacks(tox, window): """ tox.callback_friend_status(friend_status, 0) tox.callback_friend_message(friend_message, 0) - tox.callback_self_connection_status(self_connection_status(window.connection_status), 0) + tox.callback_self_connection_status(self_connection_status(window.connection_status, tox), 0) diff --git a/src/main.py b/src/main.py index 7bc9548..5e1bc6d 100644 --- a/src/main.py +++ b/src/main.py @@ -68,7 +68,8 @@ def main(): data = Profile.open_profile(path, name) tox = tox_factory(data, settings) - ms = MainWindow() + ms = MainWindow(tox) + ms.setup_info_from_tox() ms.show() # bootstrap for data in node_generator(): diff --git a/src/mainscreen.py b/src/mainscreen.py index e508036..ead650b 100644 --- a/src/mainscreen.py +++ b/src/mainscreen.py @@ -8,25 +8,35 @@ from toxcore_enums_and_consts import * class StatusCircle(QtGui.QWidget): - def __init__(self, parent=None): + def __init__(self, parent): QtGui.QWidget.__init__(self, parent) - # setGeometry(x_pos, y_pos, width, height) self.setGeometry(0, 0, 32, 32) - self.status = 0 + self.status = TOX_USER_CONNECTION_STATUS['OFFLINE'] + self.tox = parent.tox + + def mouseClick(self, event): + if self.status != TOX_USER_CONNECTION_STATUS['OFFLINE']: + self.status += 1 + self.status %= TOX_USER_CONNECTION_STATUS['OFFLINE'] + self.tox.self_set_status(self.status) + self.repaint() def paintEvent(self, event): paint = QtGui.QPainter() paint.begin(self) paint.setRenderHint(QtGui.QPainter.Antialiasing) - # make a white drawing background paint.setBrush(QtCore.Qt.white) paint.drawRect(event.rect()) k = 16 rad_x = rad_y = 10 - if not self.status: # offline - color = QtCore.Qt.red - else: + if self.status == TOX_USER_CONNECTION_STATUS['OFFLINE']: + color = QtCore.Qt.black + elif self.status == TOX_USER_CONNECTION_STATUS['ONLINE']: color = QtCore.Qt.green + elif self.status == TOX_USER_CONNECTION_STATUS['AWAY']: + color = QtCore.Qt.yellow + else: # self.status == TOX_USER_CONNECTION_STATUS['BUSY']: + color = QtCore.Qt.red paint.setPen(color) center = QtCore.QPoint(k, k) @@ -37,21 +47,23 @@ class StatusCircle(QtGui.QWidget): class MainWindow(QtGui.QMainWindow): - def __init__(self): + def __init__(self, tox): super(MainWindow, self).__init__() + self.tox = tox self.initUI() def setup_menu(self, MainWindow): self.menubar = QtGui.QMenuBar(MainWindow) self.menubar.setObjectName("menubar") + self.menubar.setHidden(True) self.menuProfile = QtGui.QMenu(self.menubar) self.menuProfile.setObjectName("menuProfile") self.menuSettings = QtGui.QMenu(self.menubar) self.menuSettings.setObjectName("menuSettings") self.menuAbout = QtGui.QMenu(self.menubar) self.menuAbout.setObjectName("menuAbout") - self.statusbar = QtGui.QStatusBar(MainWindow) - self.statusbar.setObjectName("statusbar") + #self.statusbar = QtGui.QStatusBar(MainWindow) + #self.statusbar.setObjectName("statusbar") self.actionAdd_friend = QtGui.QAction(MainWindow) self.actionAdd_friend.setObjectName("actionAdd_friend") self.actionProfile_settings = QtGui.QAction(MainWindow) @@ -145,30 +157,31 @@ class MainWindow(QtGui.QMainWindow): self.graphicsView.setMaximumSize(QtCore.QSize(64, 64)) self.graphicsView.setBaseSize(QtCore.QSize(64, 64)) self.graphicsView.setObjectName("graphicsView") - self.label = QtGui.QLabel(Form) - self.label.setGeometry(QtCore.QRect(80, 30, 191, 17)) - font = QtGui.QFont() - font.setFamily("Times New Roman") - font.setPointSize(18) - font.setWeight(75) - font.setBold(True) - self.label.setFont(font) - self.label.setObjectName("label") - self.label_2 = QtGui.QLabel(Form) - self.label_2.setGeometry(QtCore.QRect(80, 60, 191, 17)) + self.name = QtGui.QLabel(Form) + self.name.setGeometry(QtCore.QRect(80, 30, 191, 25)) font = QtGui.QFont() font.setFamily("Times New Roman") font.setPointSize(16) - font.setWeight(50) + #font.setWeight(75) + font.setBold(True) + self.name.setFont(font) + self.name.setObjectName("name") + self.status_message = QtGui.QLabel(Form) + self.status_message.setGeometry(QtCore.QRect(80, 60, 191, 17)) + font = QtGui.QFont() + font.setFamily("Times New Roman") + font.setPointSize(14) + #font.setWeight(50) font.setBold(False) - self.label_2.setFont(font) - self.label_2.setObjectName("label_2") + self.status_message.setFont(font) + self.status_message.setObjectName("status_message") self.connection_status = StatusCircle(self) self.connection_status.setGeometry(QtCore.QRect(200, 34, 64, 64)) self.connection_status.setMinimumSize(QtCore.QSize(32, 32)) self.connection_status.setMaximumSize(QtCore.QSize(32, 32)) self.connection_status.setBaseSize(QtCore.QSize(32, 32)) self.connection_status.setObjectName("connection_status") + self.connect(self.connection_status, QtCore.SIGNAL('clicked()'), self.connection_status.mouseClick) def setup_right_top(self, Form): Form.setObjectName("Form") @@ -198,6 +211,10 @@ class MainWindow(QtGui.QMainWindow): self.callButton.setText(QtGui.QApplication.translate("Form", "Start call", None, QtGui.QApplication.UnicodeUTF8)) QtCore.QMetaObject.connectSlotsByName(Form) + def setup_info_from_tox(self): + self.name.setText(str(self.tox.self_get_name().value)) + self.status_message.setText(str(self.tox.self_get_status_message().value)) + def initUI(self): main = QtGui.QWidget() grid = QtGui.QGridLayout() diff --git a/src/settings.py b/src/settings.py index 268f4dc..0e938be 100644 --- a/src/settings.py +++ b/src/settings.py @@ -1,13 +1,14 @@ from platform import system import json import os +from util import Singleton -class Settings(dict): +class Settings(dict, Singleton): def __init__(self): self.path = Settings.get_default_path() + 'toxygen.json' - if os.path.exists(self.path): + if os.path.isfile(self.path): with open(self.path) as fl: data = fl.read() super(self.__class__, self).__init__(json.loads(data)) @@ -51,4 +52,3 @@ class Settings(dict): return os.getenv('HOME') + '/.config/tox/' elif system() == 'Windows': return os.getenv('APPDATA') + '/Tox/' - diff --git a/src/toxcore_enums_and_consts.py b/src/toxcore_enums_and_consts.py index 6a4e471..19b3ca5 100644 --- a/src/toxcore_enums_and_consts.py +++ b/src/toxcore_enums_and_consts.py @@ -199,3 +199,15 @@ TOX_MAX_MESSAGE_LENGTH = 1372 TOX_MAX_NAME_LENGTH = 128 TOX_MAX_STATUS_MESSAGE_LENGTH = 1007 + +# ----------------------------------------------------------------------------------------------------------------- +# Other enums +# ----------------------------------------------------------------------------------------------------------------- + + +TOX_USER_CONNECTION_STATUS = { + 'ONLINE': 0, + 'AWAY': 1, + 'BUSY': 2, + 'OFFLINE': 3 +} diff --git a/src/util.py b/src/util.py index 0aac000..a49bd5e 100644 --- a/src/util.py +++ b/src/util.py @@ -19,3 +19,11 @@ def bin_to_string(raw_id): def curr_directory(): return os.path.dirname(os.path.realpath(__file__)) + + +class Singleton(object): + + def __new__(cls): + if not hasattr(cls, 'instance'): + cls.instance = super(Singleton, cls).__new__(cls) + return cls.instance