Browse Source

better buttons. version 0.49

283
ThomasV 13 years ago
parent
commit
54fcd4a876
  1. 64
      lib/gui_qt.py
  2. 2
      lib/version.py

64
lib/gui_qt.py

@ -516,22 +516,29 @@ class ElectrumWindow(QMainWindow):
entry.setPalette(palette) entry.setPalette(palette)
def get_current_addr(self, is_recv):
if is_recv:
l = self.receive_list
else:
l = self.contacts_list
i = l.currentItem()
if i:
return unicode( i.text(0) )
else:
return ''
def clear_buttons(self, hbox): def add_receive_buttons(self):
while hbox.count(): hbox.removeItem(hbox.itemAt(0))
def add_buttons(self, l, hbox, is_recv): l = self.receive_list
self.clear_buttons(hbox) hbox = self.receive_buttons_hbox
i = l.currentItem() hbox.addWidget(EnterButton("QR",lambda: self.show_address_qrcode(self.get_current_addr(True))))
if not i: return hbox.addWidget(EnterButton("Copy to Clipboard", lambda: self.app.clipboard().setText(self.get_current_addr(True))))
addr = unicode( i.text(0) )
hbox.addWidget(EnterButton("QR",lambda: self.show_address_qrcode(addr))) def toggle_freeze():
hbox.addWidget(EnterButton("Copy to Clipboard", lambda: self.app.clipboard().setText(addr))) addr = self.get_current_addr(True)
if is_recv: if not addr: return
def toggle_freeze(addr):
if addr in self.wallet.frozen_addresses: if addr in self.wallet.frozen_addresses:
self.wallet.frozen_addresses.remove(addr) self.wallet.frozen_addresses.remove(addr)
else: else:
@ -539,19 +546,32 @@ class ElectrumWindow(QMainWindow):
self.wallet.save() self.wallet.save()
self.update_receive_tab() self.update_receive_tab()
t = "Unfreeze" if addr in self.wallet.frozen_addresses else "Freeze" self.freezeButton = b = EnterButton("Freeze", toggle_freeze)
hbox.addWidget(EnterButton(t, lambda: toggle_freeze(addr))) hbox.addWidget(b)
hbox.addStretch(1)
else:
def payto(addr): def add_contacts_buttons(self):
l = self.contacts_list
hbox = self.contacts_buttons_hbox
hbox.addWidget(EnterButton("QR",lambda: self.show_address_qrcode(self.get_current_addr(False))))
hbox.addWidget(EnterButton("Copy to Clipboard", lambda: self.app.clipboard().setText(self.get_current_addr(False))))
def payto():
addr = self.get_current_addr(False)
if not addr:return if not addr:return
self.tabs.setCurrentIndex(1) self.tabs.setCurrentIndex(1)
self.payto_e.setText(addr) self.payto_e.setText(addr)
self.amount_e.setFocus() self.amount_e.setFocus()
hbox.addWidget(EnterButton('Pay to', lambda: payto(addr))) hbox.addWidget(EnterButton('Pay to', lambda: payto()))
hbox.addWidget(EnterButton("New", self.newaddress_dialog)) hbox.addWidget(EnterButton("New", self.newaddress_dialog))
hbox.addStretch(1) hbox.addStretch(1)
def update_receive_buttons(self):
addr = self.get_current_addr(True)
t = "Unfreeze" if addr in self.wallet.frozen_addresses else "Freeze"
self.freezeButton.setText(t)
def create_receive_tab(self): def create_receive_tab(self):
l = QTreeWidget(self) l = QTreeWidget(self)
@ -577,11 +597,15 @@ class ElectrumWindow(QMainWindow):
hbox.setSpacing(0) hbox.setSpacing(0)
buttons.setLayout(hbox) buttons.setLayout(hbox)
self.connect(l, SIGNAL('itemDoubleClicked(QTreeWidgetItem*, int)'), lambda a, b: self.address_label_clicked(a,b,l)) self.connect(l, SIGNAL('itemDoubleClicked(QTreeWidgetItem*, int)'), lambda a, b: self.address_label_clicked(a,b,l))
self.connect(l, SIGNAL('itemChanged(QTreeWidgetItem*, int)'), lambda a,b: self.address_label_changed(a,b,l)) self.connect(l, SIGNAL('itemChanged(QTreeWidgetItem*, int)'), lambda a,b: self.address_label_changed(a,b,l))
self.connect(l, SIGNAL('itemClicked(QTreeWidgetItem*, int)'), lambda: self.add_buttons(l, hbox, True)) l.selectionModel().currentChanged.connect(self.update_receive_buttons)
self.receive_list = l self.receive_list = l
self.receive_buttons_hbox = hbox self.receive_buttons_hbox = hbox
self.add_receive_buttons()
return w return w
def create_contacts_tab(self): def create_contacts_tab(self):
@ -610,16 +634,13 @@ class ElectrumWindow(QMainWindow):
self.connect(l, SIGNAL('itemDoubleClicked(QTreeWidgetItem*, int)'), lambda a, b: self.address_label_clicked(a,b,l)) self.connect(l, SIGNAL('itemDoubleClicked(QTreeWidgetItem*, int)'), lambda a, b: self.address_label_clicked(a,b,l))
self.connect(l, SIGNAL('itemChanged(QTreeWidgetItem*, int)'), lambda a,b: self.address_label_changed(a,b,l)) self.connect(l, SIGNAL('itemChanged(QTreeWidgetItem*, int)'), lambda a,b: self.address_label_changed(a,b,l))
self.connect(l, SIGNAL('itemActivated(QTreeWidgetItem*, int)'), self.show_contact_details) self.connect(l, SIGNAL('itemActivated(QTreeWidgetItem*, int)'), self.show_contact_details)
self.connect(l, SIGNAL('itemClicked(QTreeWidgetItem*, int)'), lambda: self.add_buttons(l, hbox, False))
self.contacts_list = l self.contacts_list = l
self.contacts_buttons_hbox = hbox self.contacts_buttons_hbox = hbox
self.add_contacts_buttons()
return w return w
def update_receive_tab(self): def update_receive_tab(self):
self.receive_list.clear() self.receive_list.clear()
self.clear_buttons(self.receive_buttons_hbox)
for address in self.wallet.all_addresses(): for address in self.wallet.all_addresses():
if self.wallet.is_change(address):continue if self.wallet.is_change(address):continue
label = self.wallet.labels.get(address,'') label = self.wallet.labels.get(address,'')
@ -651,7 +672,6 @@ class ElectrumWindow(QMainWindow):
def update_contacts_tab(self): def update_contacts_tab(self):
self.contacts_list.clear() self.contacts_list.clear()
self.clear_buttons(self.contacts_buttons_hbox)
for alias, v in self.wallet.aliases.items(): for alias, v in self.wallet.aliases.items():
s, target = v s, target = v

2
lib/version.py

@ -1,2 +1,2 @@
ELECTRUM_VERSION = "0.48b" ELECTRUM_VERSION = "0.49"
SEED_VERSION = 4 # bump this everytime the seed generation is modified SEED_VERSION = 4 # bump this everytime the seed generation is modified

Loading…
Cancel
Save