Browse Source

kivy: select currency first, then source. show only sources with history data

283
ThomasV 9 years ago
parent
commit
a5fd6d2e6c
  1. 47
      gui/kivy/uix/dialogs/fx_dialog.py
  2. 34
      plugins/exchange_rate/exchange_rate.py

47
gui/kivy/uix/dialogs/fx_dialog.py

@ -29,12 +29,12 @@ Builder.load_string('''
orientation: 'horizontal' orientation: 'horizontal'
size_hint: 1, 0.1 size_hint: 1, 0.1
Label: Label:
text: _('Source') text: _('Currency')
height: '48dp' height: '48dp'
Spinner: Spinner:
height: '48dp' height: '48dp'
id: exchanges id: ccy
on_text: popup.on_exchange(self.text) on_text: popup.on_currency(self.text)
Widget: Widget:
size_hint: 1, 0.1 size_hint: 1, 0.1
@ -43,12 +43,13 @@ Builder.load_string('''
orientation: 'horizontal' orientation: 'horizontal'
size_hint: 1, 0.1 size_hint: 1, 0.1
Label: Label:
text: _('Currency') text: _('Source')
height: '48dp' height: '48dp'
Spinner: Spinner:
height: '48dp' height: '48dp'
id: ccy id: exchanges
on_text: popup.on_currency(self.text) on_text: popup.on_exchange(self.text)
Widget: Widget:
size_hint: 1, 0.2 size_hint: 1, 0.2
@ -80,8 +81,6 @@ from functools import partial
class FxDialog(Factory.Popup): class FxDialog(Factory.Popup):
__events__ = ('on_quotes', )
def __init__(self, app, plugins, config, callback): def __init__(self, app, plugins, config, callback):
Factory.Popup.__init__(self) Factory.Popup.__init__(self)
self.app = app self.app = app
@ -90,11 +89,6 @@ class FxDialog(Factory.Popup):
self.plugins = plugins self.plugins = plugins
p = self.plugins.get('exchange_rate') p = self.plugins.get('exchange_rate')
self.ids.enabled.active = bool(p) self.ids.enabled.active = bool(p)
if p:
p.dispatcher.bind(on_quotes=self.on_quotes)
def on_quotes(self, b):
self.add_currencies()
def on_active(self, b): def on_active(self, b):
if b: if b:
@ -102,21 +96,17 @@ class FxDialog(Factory.Popup):
if p is None: if p is None:
p = self.plugins.enable('exchange_rate') p = self.plugins.enable('exchange_rate')
p.init_kivy(self.app) p.init_kivy(self.app)
p.dispatcher.bind(on_quotes=self.on_quotes)
values = sorted(p.exchanges.keys())
text = p.exchange.name()
else: else:
self.plugins.disable('exchange_rate') self.plugins.disable('exchange_rate')
values = []
text = ''
Clock.schedule_once(lambda dt: self.add_exchanges(values, text))
Clock.schedule_once(lambda dt: self.add_currencies()) Clock.schedule_once(lambda dt: self.add_currencies())
def add_exchanges(self, values, text): def add_exchanges(self):
p = self.plugins.get('exchange_rate')
exchanges = sorted(p.exchanges_by_ccy.get(p.get_currency())) if p else []
mx = p.exchange.name() if p else ''
ex = self.ids.exchanges ex = self.ids.exchanges
ex.values = values ex.values = exchanges
ex.text = text ex.text = (mx if mx in exchanges else exchanges[0]) if p else ''
def on_exchange(self, text): def on_exchange(self, text):
if not text: if not text:
@ -127,16 +117,15 @@ class FxDialog(Factory.Popup):
def add_currencies(self): def add_currencies(self):
p = self.plugins.get('exchange_rate') p = self.plugins.get('exchange_rate')
currencies = sorted(p.exchange.quotes.keys()) if p else [] currencies = sorted(p.exchanges_by_ccy.keys()) if p else []
my_ccy = p.get_currency() if p else ''
self.ids.ccy.values = currencies self.ids.ccy.values = currencies
my_ccy = p.get_currency() if p else None self.ids.ccy.text = my_ccy
if currencies:
self.ids.ccy.text = my_ccy if my_ccy in currencies else currencies[0]
def on_currency(self, ccy): def on_currency(self, ccy):
if not ccy: if ccy:
return
p = self.plugins.get('exchange_rate') p = self.plugins.get('exchange_rate')
if p and ccy != p.get_currency(): if p and ccy != p.get_currency():
p.set_currency(ccy) p.set_currency(ccy)
self.app.fiat_unit = ccy self.app.fiat_unit = ccy
Clock.schedule_once(lambda dt: self.add_exchanges())

34
plugins/exchange_rate/exchange_rate.py

@ -260,6 +260,32 @@ class Winkdex(ExchangeBase):
for h in history]) for h in history])
def dictinvert(d):
inv = {}
for k, vlist in d.iteritems():
for v in vlist:
keys = inv.setdefault(v, [])
keys.append(k)
return inv
def get_exchanges():
is_exchange = lambda obj: (inspect.isclass(obj)
and issubclass(obj, ExchangeBase)
and obj != ExchangeBase)
return dict(inspect.getmembers(sys.modules[__name__], is_exchange))
def get_exchanges_by_ccy():
"return only the exchanges that have history rates (which is hardcoded)"
d = {}
exchanges = get_exchanges()
for name, klass in exchanges.items():
exchange = klass(None, None)
d[name] = exchange.history_ccys()
return dictinvert(d)
class FxPlugin(BasePlugin, ThreadJob): class FxPlugin(BasePlugin, ThreadJob):
def __init__(self, parent, config, name): def __init__(self, parent, config, name):
@ -268,11 +294,8 @@ class FxPlugin(BasePlugin, ThreadJob):
self.history_used_spot = False self.history_used_spot = False
self.ccy_combo = None self.ccy_combo = None
self.hist_checkbox = None self.hist_checkbox = None
is_exchange = lambda obj: (inspect.isclass(obj) self.exchanges = get_exchanges()
and issubclass(obj, ExchangeBase) self.exchanges_by_ccy = get_exchanges_by_ccy()
and obj != ExchangeBase)
self.exchanges = dict(inspect.getmembers(sys.modules[__name__],
is_exchange))
self.set_exchange(self.config_exchange()) self.set_exchange(self.config_exchange())
def ccy_amount_str(self, amount, commas): def ccy_amount_str(self, amount, commas):
@ -370,4 +393,3 @@ class FxPlugin(BasePlugin, ThreadJob):
def historical_value_str(self, satoshis, d_t): def historical_value_str(self, satoshis, d_t):
rate = self.history_rate(d_t) rate = self.history_rate(d_t)
return self.value_str(satoshis, rate) return self.value_str(satoshis, rate)

Loading…
Cancel
Save