Browse Source

add base unit setting and conversion methods in qeconfig.py

patch-4
Sander van Grieken 3 years ago
parent
commit
426198dd42
  1. 60
      electrum/gui/qml/qeconfig.py

60
electrum/gui/qml/qeconfig.py

@ -1,5 +1,7 @@
from PyQt5.QtCore import pyqtProperty, pyqtSignal, pyqtSlot, QObject from PyQt5.QtCore import pyqtProperty, pyqtSignal, pyqtSlot, QObject
from decimal import Decimal
from electrum.logging import get_logger from electrum.logging import get_logger
class QEConfig(QObject): class QEConfig(QObject):
@ -10,9 +12,6 @@ class QEConfig(QObject):
_logger = get_logger(__name__) _logger = get_logger(__name__)
autoConnectChanged = pyqtSignal() autoConnectChanged = pyqtSignal()
serverStringChanged = pyqtSignal()
manualServerChanged = pyqtSignal()
@pyqtProperty(bool, notify=autoConnectChanged) @pyqtProperty(bool, notify=autoConnectChanged)
def autoConnect(self): def autoConnect(self):
return self.config.get('auto_connect') return self.config.get('auto_connect')
@ -27,6 +26,7 @@ class QEConfig(QObject):
def autoConnectDefined(self): def autoConnectDefined(self):
return self.config.get('auto_connect') is not None return self.config.get('auto_connect') is not None
serverStringChanged = pyqtSignal()
@pyqtProperty('QString', notify=serverStringChanged) @pyqtProperty('QString', notify=serverStringChanged)
def serverString(self): def serverString(self):
return self.config.get('server') return self.config.get('server')
@ -36,6 +36,7 @@ class QEConfig(QObject):
self.config.set_key('server', server, True) self.config.set_key('server', server, True)
self.serverStringChanged.emit() self.serverStringChanged.emit()
manualServerChanged = pyqtSignal()
@pyqtProperty(bool, notify=manualServerChanged) @pyqtProperty(bool, notify=manualServerChanged)
def manualServer(self): def manualServer(self):
return self.config.get('oneserver') return self.config.get('oneserver')
@ -45,3 +46,56 @@ class QEConfig(QObject):
self.config.set_key('oneserver', oneserver, True) self.config.set_key('oneserver', oneserver, True)
self.manualServerChanged.emit() self.manualServerChanged.emit()
baseUnitChanged = pyqtSignal()
@pyqtProperty(str, notify=baseUnitChanged)
def baseUnit(self):
return self.config.get_base_unit()
@baseUnit.setter
def baseUnit(self, unit):
self.config.set_base_unit(unit)
self.baseUnitChanged.emit()
thousandsSeparatorChanged = pyqtSignal()
@pyqtProperty(bool, notify=thousandsSeparatorChanged)
def thousandsSeparator(self):
return self.config.get('amt_add_thousands_sep', False)
@thousandsSeparator.setter
def thousandsSeparator(self, checked):
self.config.set_key('amt_add_thousands_sep', checked)
self.config.amt_add_thousands_sep = checked
self.thousandsSeparatorChanged.emit()
@pyqtSlot(int, result=str)
@pyqtSlot(int, bool, result=str)
def formatSats(self, satoshis, with_unit=False):
if with_unit:
return self.config.format_amount_and_units(satoshis)
else:
return self.config.format_amount(satoshis)
# TODO delegate all this to config.py/util.py
def decimal_point(self):
return self.config.get('decimal_point')
def max_precision(self):
return self.decimal_point() + 0 #self.extra_precision
@pyqtSlot(str, result=int)
def unitsToSats(self, unitAmount):
# returns amt in satoshis
try:
x = Decimal(unitAmount)
except:
return None
# scale it to max allowed precision, make it an int
max_prec_amount = int(pow(10, self.max_precision()) * x)
# if the max precision is simply what unit conversion allows, just return
if self.max_precision() == self.decimal_point():
return max_prec_amount
# otherwise, scale it back to the expected unit
#amount = Decimal(max_prec_amount) / Decimal(pow(10, self.max_precision()-self.decimal_point()))
#return int(amount) #Decimal(amount) if not self.is_int else int(amount)

Loading…
Cancel
Save