|
@ -25,6 +25,7 @@ |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
from electrum.i18n import _ |
|
|
from electrum.i18n import _ |
|
|
|
|
|
from electrum.bitcoin import is_address |
|
|
from electrum.util import block_explorer_URL, format_satoshis, format_time, age |
|
|
from electrum.util import block_explorer_URL, format_satoshis, format_time, age |
|
|
from electrum.plugins import run_hook |
|
|
from electrum.plugins import run_hook |
|
|
from electrum.paymentrequest import PR_UNPAID, PR_PAID, PR_UNKNOWN, PR_EXPIRED |
|
|
from electrum.paymentrequest import PR_UNPAID, PR_PAID, PR_UNKNOWN, PR_EXPIRED |
|
@ -36,7 +37,7 @@ from util import MyTreeWidget, pr_tooltips, pr_icons |
|
|
class ContactList(MyTreeWidget): |
|
|
class ContactList(MyTreeWidget): |
|
|
|
|
|
|
|
|
def __init__(self, parent): |
|
|
def __init__(self, parent): |
|
|
MyTreeWidget.__init__(self, parent, self.create_menu, [_('Name'), _('Type'), _('Value')], 0, [0]) |
|
|
MyTreeWidget.__init__(self, parent, self.create_menu, [_('Name'), _('Address')], 0, [0]) |
|
|
self.setSelectionMode(QAbstractItemView.ExtendedSelection) |
|
|
self.setSelectionMode(QAbstractItemView.ExtendedSelection) |
|
|
self.setSortingEnabled(True) |
|
|
self.setSortingEnabled(True) |
|
|
|
|
|
|
|
@ -56,8 +57,7 @@ class ContactList(MyTreeWidget): |
|
|
menu.addAction(_("New contact"), lambda: self.parent.new_contact_dialog()) |
|
|
menu.addAction(_("New contact"), lambda: self.parent.new_contact_dialog()) |
|
|
else: |
|
|
else: |
|
|
names = [unicode(item.text(0)) for item in selected] |
|
|
names = [unicode(item.text(0)) for item in selected] |
|
|
types = [unicode(item.text(1)) for item in selected] |
|
|
keys = [unicode(item.text(1)) for item in selected] |
|
|
keys = [unicode(item.text(2)) for item in selected] |
|
|
|
|
|
column = self.currentColumn() |
|
|
column = self.currentColumn() |
|
|
column_title = self.headerItem().text(column) |
|
|
column_title = self.headerItem().text(column) |
|
|
column_data = '\n'.join([unicode(item.text(column)) for item in selected]) |
|
|
column_data = '\n'.join([unicode(item.text(column)) for item in selected]) |
|
@ -68,13 +68,9 @@ class ContactList(MyTreeWidget): |
|
|
|
|
|
|
|
|
menu.addAction(_("Pay to"), lambda: self.parent.payto_contacts(keys)) |
|
|
menu.addAction(_("Pay to"), lambda: self.parent.payto_contacts(keys)) |
|
|
menu.addAction(_("Delete"), lambda: self.parent.delete_contacts(keys)) |
|
|
menu.addAction(_("Delete"), lambda: self.parent.delete_contacts(keys)) |
|
|
URLs = [] |
|
|
URLs = [block_explorer_URL(self.config, 'addr', key) for key in filter(is_address, keys)] |
|
|
for (addr, _type) in zip(keys, types): |
|
|
|
|
|
if _type == 'address': |
|
|
|
|
|
URLs.append(block_explorer_URL(self.config, 'addr', addr)) |
|
|
|
|
|
if URLs: |
|
|
if URLs: |
|
|
menu.addAction(_("View on block explorer"), |
|
|
menu.addAction(_("View on block explorer"), lambda: map(webbrowser.open, URLs)) |
|
|
lambda: map(webbrowser.open, URLs)) |
|
|
|
|
|
|
|
|
|
|
|
run_hook('create_contact_menu', menu, selected) |
|
|
run_hook('create_contact_menu', menu, selected) |
|
|
menu.exec_(self.viewport().mapToGlobal(position)) |
|
|
menu.exec_(self.viewport().mapToGlobal(position)) |
|
@ -85,7 +81,7 @@ class ContactList(MyTreeWidget): |
|
|
self.clear() |
|
|
self.clear() |
|
|
for key in sorted(self.parent.contacts.keys()): |
|
|
for key in sorted(self.parent.contacts.keys()): |
|
|
_type, name = self.parent.contacts[key] |
|
|
_type, name = self.parent.contacts[key] |
|
|
item = QTreeWidgetItem([name, _type, key]) |
|
|
item = QTreeWidgetItem([name, key]) |
|
|
item.setData(0, Qt.UserRole, key) |
|
|
item.setData(0, Qt.UserRole, key) |
|
|
self.addTopLevelItem(item) |
|
|
self.addTopLevelItem(item) |
|
|
if key == current_key: |
|
|
if key == current_key: |
|
|