UI refactoring, part 2 #1394

Open
g1itch wants to merge 14 commits from g1itch/ui-refactoring into v0.6
4 changed files with 76 additions and 9 deletions
Showing only changes of commit 25e362c338 - Show all commits

View File

@ -308,7 +308,6 @@ class MainWindow(Window):
def __init__(self, parent=None): def __init__(self, parent=None):
super(MainWindow, self).__init__(parent) super(MainWindow, self).__init__(parent)
self.qmytranslator = self.qsystranslator = None
self.indicatorUpdate = None self.indicatorUpdate = None
self.actionStatus = None self.actionStatus = None
@ -1269,8 +1268,8 @@ class MainWindow(Window):
def changeEvent(self, event): def changeEvent(self, event):
if event.type() == QtCore.QEvent.LanguageChange: if event.type() == QtCore.QEvent.LanguageChange:
self.retranslateUi(self) # FIXME: it's called very often
self.init_inbox_popup_menu(False) self.retranslateUi()
self.init_identities_popup_menu(False) self.init_identities_popup_menu(False)
self.blackwhitelist.init_blacklist_popup_menu() self.blackwhitelist.init_blacklist_popup_menu()
if event.type() == QtCore.QEvent.WindowStateChange: if event.type() == QtCore.QEvent.WindowStateChange:

View File

@ -1,7 +1,7 @@
""" """
Dialogs that work with BM address. Dialogs that work with BM address.
""" """
# pylint: disable=attribute-defined-outside-init,too-few-public-methods,relative-import # pylint: disable=attribute-defined-outside-init,too-few-public-methods
import hashlib import hashlib
@ -9,8 +9,11 @@ from PyQt4 import QtCore, QtGui
import queues import queues
import widgets import widgets
from account import AccountMixin, GatewayAccount, MailchuckAccount, accountClass, getSortedAccounts from account import (
from addresses import addBMIfNotPresent, decodeAddress, encodeVarint GatewayAccount, MailchuckAccount, AccountMixin, accountClass,
getSortedAccounts
)
from addresses import decodeAddress, encodeVarint, addBMIfNotPresent
from inventory import Inventory from inventory import Inventory
from tr import _translate from tr import _translate

View File

@ -1,20 +1,26 @@
import locale
import os
import sys
from PyQt4 import QtCore, QtGui from PyQt4 import QtCore, QtGui
import l10n
import paths
import settingsmixin import settingsmixin
import widgets import widgets
from bmconfigparser import BMConfigParser from bmconfigparser import BMConfigParser
from debug import logger
from foldertree import AddressBookCompleter from foldertree import AddressBookCompleter
from retranslateui import RetranslateMixin
from tr import _translate from tr import _translate
class Window(settingsmixin.SMainWindow, RetranslateMixin): class Window(settingsmixin.SMainWindow):
"""The main PyBitmessage's window""" """The main PyBitmessage's window"""
def __init__(self, parent=None): def __init__(self, parent=None):
super(Window, self).__init__(parent) super(Window, self).__init__(parent)
widgets.load('main.ui', self) widgets.load('main.ui', self)
self.qmytranslator = self.qsystranslator = None
self.blackwhitelist.rerenderBlackWhiteList() self.blackwhitelist.rerenderBlackWhiteList()
addressBookCompleter = AddressBookCompleter() addressBookCompleter = AddressBookCompleter()
@ -82,3 +88,62 @@ class Window(settingsmixin.SMainWindow, RetranslateMixin):
if dontconnect else if dontconnect else
_translate("MainWindow", "Go offline", None) _translate("MainWindow", "Go offline", None)
) )
def retranslateUi(self):
"""Update widgets' texts which is not taken from ui-file"""
self.updateHumanFriendlyTTLDescription(int(
self.horizontalSliderTTL.tickPosition() ** 3.199 + 3600))
self.networkstatus.retranslateUi()
# FIXME: this is not best place for this func
def change_translation(self, newlocale=None):
"""Change translation language for the application"""
if newlocale is None:
newlocale = l10n.getTranslationLanguage()
try:
if not self.qmytranslator.isEmpty():
QtGui.QApplication.removeTranslator(self.qmytranslator)
except:
pass
try:
if not self.qsystranslator.isEmpty():
QtGui.QApplication.removeTranslator(self.qsystranslator)
except:
pass
self.qmytranslator = QtCore.QTranslator()
translationpath = os.path.join(
paths.codePath(), 'translations', 'bitmessage_' + newlocale)
self.qmytranslator.load(translationpath)
QtGui.QApplication.installTranslator(self.qmytranslator)
self.qsystranslator = QtCore.QTranslator()
if paths.frozen:
translationpath = os.path.join(
paths.codePath(), 'translations', 'qt_' + newlocale)
else:
translationpath = os.path.join(
str(QtCore.QLibraryInfo.location(
QtCore.QLibraryInfo.TranslationsPath)), 'qt_' + newlocale)
self.qsystranslator.load(translationpath)
QtGui.QApplication.installTranslator(self.qsystranslator)
lang = locale.normalize(l10n.getTranslationLanguage())
langs = [
lang.split(".")[0] + "." + l10n.encoding,
lang.split(".")[0] + "." + 'UTF-8',
lang
]
if 'win32' in sys.platform or 'win64' in sys.platform:
langs = [l10n.getWindowsLocale(lang)]
for lang in langs:
try:
l10n.setlocale(locale.LC_ALL, lang)
if 'win32' not in sys.platform and 'win64' not in sys.platform:
l10n.encoding = locale.nl_langinfo(locale.CODESET)
else:
l10n.encoding = locale.getlocale()[1]
logger.info("Successfully set locale to %s", lang)
break
except:
logger.error("Failed to set locale to %s", lang, exc_info=True)

View File

@ -240,7 +240,7 @@ class NetworkStatus(QtGui.QWidget, RetranslateMixin):
self.labelTotalConnections.setText( self.labelTotalConnections.setText(
_translate( _translate(
"networkstatus", "Total Connections: %1").arg( "networkstatus", "Total Connections: %1").arg(
str(self.tableWidgetConnectionCount.rowCount()))) self.tableWidgetConnectionCount.rowCount()))
self.labelStartupTime.setText(_translate( self.labelStartupTime.setText(_translate(
"networkstatus", "Since startup on %1" "networkstatus", "Since startup on %1"
).arg(l10n.formatTimestamp(self.startup))) ).arg(l10n.formatTimestamp(self.startup)))