Browse Source

'import private keys' may import several keys

283
thomasv 12 years ago
parent
commit
e3bb6f8879
  1. 69
      gui/gui_classic.py

69
gui/gui_classic.py

@ -226,7 +226,6 @@ class StatusBarButton(QPushButton):
def waiting_dialog(f): def waiting_dialog(f):
s = Timer() s = Timer()
@ -248,19 +247,35 @@ def waiting_dialog(f):
w.destroy() w.destroy()
def ok_cancel_buttons(dialog): def ok_cancel_buttons(dialog, ok_label=_("OK") ):
hbox = QHBoxLayout() hbox = QHBoxLayout()
hbox.addStretch(1) hbox.addStretch(1)
b = QPushButton("Cancel") b = QPushButton(_("Cancel"))
hbox.addWidget(b) hbox.addWidget(b)
b.clicked.connect(dialog.reject) b.clicked.connect(dialog.reject)
b = QPushButton("OK") b = QPushButton(ok_label)
hbox.addWidget(b) hbox.addWidget(b)
b.clicked.connect(dialog.accept) b.clicked.connect(dialog.accept)
b.setDefault(True) b.setDefault(True)
return hbox return hbox
def text_dialog(parent, title, label, ok_label):
dialog = QDialog(parent)
dialog.setMinimumWidth(500)
dialog.setWindowTitle(title)
dialog.setModal(1)
l = QVBoxLayout()
dialog.setLayout(l)
l.addWidget(QLabel(label))
txt = QTextEdit()
l.addWidget(txt)
l.addLayout(ok_cancel_buttons(dialog, ok_label))
if dialog.exec_():
return unicode(txt.toPlainText())
default_column_widths = { "history":[40,140,350,140], "contacts":[350,330], default_column_widths = { "history":[40,140,350,140], "contacts":[350,330],
"receive":[[370],[370,200,130]] } "receive":[[370],[370,200,130]] }
@ -1729,23 +1744,10 @@ class ElectrumWindow(QMainWindow):
self.show_message("There was a problem sending your transaction:\n %s" % (result_message)) self.show_message("There was a problem sending your transaction:\n %s" % (result_message))
def do_process_from_text(self): def do_process_from_text(self):
dialog = QDialog(self) text = text_dialog(self, _('Input raw transaction'), _("Transaction:"), _("Load transaction"))
dialog.setMinimumWidth(500) if not text:
dialog.setWindowTitle(_('Input raw transaction')) return
dialog.setModal(1) tx_dict = self.tx_dict_from_text(text)
l = QVBoxLayout()
dialog.setLayout(l)
l.addWidget(QLabel(_("Transaction:")))
txt = QTextEdit()
l.addWidget(txt)
ok_button = QPushButton(_("Load transaction"))
ok_button.setDefault(True)
ok_button.clicked.connect(dialog.accept)
l.addWidget(ok_button)
dialog.exec_()
tx_dict = self.tx_dict_from_text(unicode(txt.toPlainText()))
if tx_dict: if tx_dict:
self.create_process_transaction_window(tx_dict) self.create_process_transaction_window(tx_dict)
@ -1858,19 +1860,28 @@ class ElectrumWindow(QMainWindow):
+ _('Are you sure you understand what you are doing?'), 3, 4) + _('Are you sure you understand what you are doing?'), 3, 4)
if r == 4: return if r == 4: return
text, ok = QInputDialog.getText(self, _('Import private key'), _('Private Key') + ':') text = text_dialog(self, _('Import private keys'), _("Enter private keys")+':', _("Import"))
if not ok: return if not text: return
sec = str(text).strip()
text = str(text).split()
badkeys = []
addrlist = []
for key in text:
try: try:
addr = self.wallet.import_key(sec, password) addr = self.wallet.import_key(key, password)
except BaseException as e:
badkeys.append(key)
continue
if not addr: if not addr:
QMessageBox.critical(None, _("Unable to import key"), "error") badkeys.append(key)
else: else:
QMessageBox.information(None, _("Key imported"), addr) addrlist.append(addr)
if addrlist:
QMessageBox.information(self, _('Information'), _("The following addresses were added") + ':\n' + '\n'.join(addrlist))
if badkeys:
QMessageBox.critical(self, _('Error'), _("The following inputs could not be imported") + ':\n'+ '\n'.join(badkeys))
self.update_receive_tab() self.update_receive_tab()
self.update_history_tab() self.update_history_tab()
except BaseException as e:
QMessageBox.critical(None, _("Unable to import key"), str(e))
def settings_dialog(self): def settings_dialog(self):

Loading…
Cancel
Save