diff --git a/gui/kivy/uix/screens.py b/gui/kivy/uix/screens.py index 15606736e..355fb38a1 100644 --- a/gui/kivy/uix/screens.py +++ b/gui/kivy/uix/screens.py @@ -105,9 +105,6 @@ class HistoryScreen(CScreen): d = LabelDialog(_('Enter Transaction Label'), text, callback) d.open() - def get_history_rate(self, btc_balance, timestamp): - date = timestamp_to_datetime(timestamp) - return run_hook('historical_value_str', btc_balance, date) def parse_history(self, items): for item in items: @@ -125,7 +122,6 @@ class HistoryScreen(CScreen): time_str = _('pending') icon = "atlas://gui/kivy/theming/light/unconfirmed" elif conf < 6: - time_str = '' # add new to fix error when conf < 0 conf = max(1, conf) icon = "atlas://gui/kivy/theming/light/clock{}".format(conf) else: @@ -137,9 +133,10 @@ class HistoryScreen(CScreen): label = _('Pruned transaction outputs') is_default_label = False - quote_currency = 'USD' - rate = self.get_history_rate(value, timestamp) - quote_text = "..." if rate is None else "{0:.3} {1}".format(rate, quote_currency) + date = timestamp_to_datetime(timestamp) + rate = run_hook('history_rate', date) + if self.app.fiat_unit: + quote_text = "..." if rate is None else "{0:.3} {1}".format(Decimal(value) / 100000000 * Decimal(rate), self.app.fiat_unit) yield (conf, icon, time_str, label, value, tx_hash, quote_text) diff --git a/plugins/exchange_rate/exchange_rate.py b/plugins/exchange_rate/exchange_rate.py index 30dce1ba9..0a11039dd 100644 --- a/plugins/exchange_rate/exchange_rate.py +++ b/plugins/exchange_rate/exchange_rate.py @@ -341,13 +341,18 @@ class FxPlugin(BasePlugin, ThreadJob): return _("No data") @hook - def historical_value_str(self, satoshis, d_t): + def history_rate(self, d_t): rate = self.exchange.historical_rate(self.ccy, d_t) # Frequently there is no rate for today, until tomorrow :) # Use spot quotes in that case if rate is None and (datetime.today().date() - d_t.date()).days <= 2: rate = self.exchange.quotes.get(self.ccy) self.history_used_spot = True + return rate + + @hook + def historical_value_str(self, satoshis, d_t): + rate = self.history_rate(d_t) return self.value_str(satoshis, rate) @hook