3 changed files with 165 additions and 0 deletions
@ -0,0 +1,159 @@
|
||||
from PyQt4.QtGui import * |
||||
from electrum.plugins import BasePlugin, hook |
||||
from electrum.i18n import _ |
||||
|
||||
|
||||
import datetime |
||||
from electrum.util import format_satoshis |
||||
|
||||
|
||||
try: |
||||
import matplotlib.pyplot as plt |
||||
import matplotlib.dates as md |
||||
from matplotlib.patches import Ellipse |
||||
from matplotlib.offsetbox import AnchoredOffsetbox, TextArea, DrawingArea, HPacker |
||||
flag_matlib=True |
||||
except: |
||||
flag_matlib=False |
||||
|
||||
|
||||
|
||||
|
||||
|
||||
class Plugin(BasePlugin): |
||||
|
||||
|
||||
def fullname(self): |
||||
return 'Plot History' |
||||
|
||||
def description(self): |
||||
return '%s\n%s' % (_("Ability to plot transaction history in graphical mode."), _("Warning: Requires matplotlib library.")) |
||||
|
||||
def is_available(self): |
||||
if flag_matlib: |
||||
return True |
||||
else: |
||||
return False |
||||
|
||||
|
||||
|
||||
def is_enabled(self): |
||||
if not self.is_available(): |
||||
return False |
||||
else: |
||||
return True |
||||
|
||||
|
||||
@hook |
||||
def init_qt(self, gui): |
||||
self.win = gui.main_window |
||||
|
||||
@hook |
||||
def export_history_dialog(self, d,hbox): |
||||
self.wallet = d.wallet |
||||
|
||||
history = self.wallet.get_tx_history() |
||||
|
||||
if len(history) > 0: |
||||
b = QPushButton(_("Preview plot")) |
||||
hbox.addWidget(b) |
||||
b.clicked.connect(lambda: self.do_plot(self.wallet)) |
||||
else: |
||||
b = QPushButton(_("No history to plot")) |
||||
hbox.addWidget(b) |
||||
|
||||
|
||||
|
||||
def do_plot(self,wallet): |
||||
history = wallet.get_tx_history() |
||||
balance_Val=[] |
||||
fee_val=[] |
||||
value_val=[] |
||||
datenums=[] |
||||
unknown_trans=0 |
||||
pending_trans=0 |
||||
counter_trans=0 |
||||
for item in history: |
||||
tx_hash, confirmations, is_mine, value, fee, balance, timestamp = item |
||||
if confirmations: |
||||
if timestamp is not None: |
||||
try: |
||||
datenums.append(md.date2num(datetime.datetime.fromtimestamp(timestamp))) |
||||
balance_string = format_satoshis(balance, False) |
||||
balance_Val.append(float((format_satoshis(balance,False)))*1000.0) |
||||
except [RuntimeError, TypeError, NameError] as reason: |
||||
unknown_trans=unknown_trans+1 |
||||
pass |
||||
else: |
||||
unknown_trans=unknown_trans+1 |
||||
else: |
||||
pending_trans=pending_trans+1 |
||||
|
||||
if value is not None: |
||||
value_string = format_satoshis(value, True) |
||||
value_val.append(float(value_string)*1000.0) |
||||
else: |
||||
value_string = '--' |
||||
|
||||
if fee is not None: |
||||
fee_string = format_satoshis(fee, True) |
||||
fee_val.append(float(fee_string)) |
||||
else: |
||||
fee_string = '0' |
||||
|
||||
if tx_hash: |
||||
label, is_default_label = wallet.get_label(tx_hash) |
||||
label = label.encode('utf-8') |
||||
else: |
||||
label = "" |
||||
|
||||
|
||||
f, axarr = plt.subplots(2, sharex=True) |
||||
|
||||
plt.subplots_adjust(bottom=0.2) |
||||
plt.xticks( rotation=25 ) |
||||
ax=plt.gca() |
||||
x=19 |
||||
test11="Unknown transactions = "+str(unknown_trans)+" Pending transactions = "+str(pending_trans)+" ." |
||||
box1 = TextArea(" Test : Number of pending transactions", textprops=dict(color="k")) |
||||
box1.set_text(test11) |
||||
|
||||
|
||||
box = HPacker(children=[box1], |
||||
align="center", |
||||
pad=0.1, sep=15) |
||||
|
||||
anchored_box = AnchoredOffsetbox(loc=3, |
||||
child=box, pad=0.5, |
||||
frameon=True, |
||||
bbox_to_anchor=(0.5, 1.02), |
||||
bbox_transform=ax.transAxes, |
||||
borderpad=0.5, |
||||
) |
||||
|
||||
|
||||
ax.add_artist(anchored_box) |
||||
|
||||
|
||||
plt.ylabel('mBTC') |
||||
plt.xlabel('Dates') |
||||
xfmt = md.DateFormatter('%Y-%m-%d') |
||||
ax.xaxis.set_major_formatter(xfmt) |
||||
|
||||
|
||||
axarr[0].plot(datenums,balance_Val,marker='o',linestyle='-',color='blue',label='Balance') |
||||
axarr[0].legend(loc='upper left') |
||||
axarr[0].set_title('History Transactions') |
||||
|
||||
|
||||
xfmt = md.DateFormatter('%Y-%m-%d') |
||||
ax.xaxis.set_major_formatter(xfmt) |
||||
axarr[1].plot(datenums,fee_val,marker='o',linestyle='-',color='red',label='Fee') |
||||
axarr[1].plot(datenums,value_val,marker='o',linestyle='-',color='green',label='Value') |
||||
|
||||
|
||||
|
||||
|
||||
axarr[1].legend(loc='upper left') |
||||
# plt.annotate('unknown transaction = %d \n pending transactions = %d' %(unknown_trans,pending_trans),xy=(0.7,0.05),xycoords='axes fraction',size=12) |
||||
plt.show() |
||||
Loading…
Reference in new issue