1 from electrum.i18n import _
2 from PyQt4.QtGui import *
3 from PyQt4.QtCore import *
10 class WaitingDialog(QThread):
11 def __init__(self, parent, message, run_task, on_complete=None):
12 QThread.__init__(self)
14 self.d = QDialog(parent)
15 self.d.setWindowTitle('Please wait')
17 vbox = QVBoxLayout(self.d)
19 self.run_task = run_task
20 self.on_complete = on_complete
21 self.d.connect(self.d, SIGNAL('done'), self.close)
27 self.result = self.run_task()
28 except Exception as e:
29 traceback.print_exc(file=sys.stdout)
31 self.d.emit(SIGNAL('done'))
36 QMessageBox.warning(self.parent, _('Error'), self.error, _('OK'))
40 self.on_complete(*self.result)
47 self.emit(SIGNAL('timersignal'))
51 class EnterButton(QPushButton):
52 def __init__(self, text, func):
53 QPushButton.__init__(self, text)
55 self.clicked.connect(func)
57 def keyPressEvent(self, e):
58 if e.key() == Qt.Key_Return:
65 class HelpButton(QPushButton):
66 def __init__(self, text):
67 QPushButton.__init__(self, '?')
69 self.setFocusPolicy(Qt.NoFocus)
70 self.setFixedWidth(20)
72 self.clicked.connect(self.onclick)
74 def set_alt(self, func):
81 QMessageBox.information(self, 'Help', self.help_text, 'OK')
85 def close_button(dialog, label=_("Close") ):
88 b = QPushButton(label)
90 b.clicked.connect(dialog.close)
94 def ok_cancel_buttons2(dialog, ok_label=_("OK") ):
97 b = QPushButton(_("Cancel"))
99 b.clicked.connect(dialog.reject)
100 b = QPushButton(ok_label)
102 b.clicked.connect(dialog.accept)
106 def ok_cancel_buttons(dialog, ok_label=_("OK") ):
107 hbox, b = ok_cancel_buttons2(dialog, ok_label)
110 def text_dialog(parent, title, label, ok_label, default=None):
111 from qrtextedit import QRTextEdit
112 dialog = QDialog(parent)
113 dialog.setMinimumWidth(500)
114 dialog.setWindowTitle(title)
118 l.addWidget(QLabel(label))
123 l.addLayout(ok_cancel_buttons(dialog, ok_label))
125 return unicode(txt.toPlainText())
129 def address_field(addresses):
131 address_e = QLineEdit()
133 address_e.setText(addresses[0])
135 i = addresses.index(str(address_e.text())) + 1
136 i = i % len(addresses)
137 address_e.setText(addresses[i])
138 button = QPushButton(_('Address'))
139 button.clicked.connect(func)
140 hbox.addWidget(button)
141 hbox.addWidget(address_e)
142 return hbox, address_e
145 def filename_field(parent, config, defaultname, select_msg):
148 vbox.addWidget(QLabel(_("Format")))
149 gb = QGroupBox("format", parent)
150 b1 = QRadioButton(gb)
153 b2 = QRadioButton(gb)
154 b2.setText(_("json"))
160 directory = config.get('io_dir', unicode(os.path.expanduser('~')))
161 path = os.path.join( directory, defaultname )
162 filename_e = QLineEdit()
163 filename_e.setText(path)
166 text = unicode(filename_e.text())
167 _filter = "*.csv" if text.endswith(".csv") else "*.json" if text.endswith(".json") else None
168 p = unicode( QFileDialog.getSaveFileName(None, select_msg, text, _filter))
170 filename_e.setText(p)
172 button = QPushButton(_('File'))
173 button.clicked.connect(func)
174 hbox.addWidget(button)
175 hbox.addWidget(filename_e)
179 text = unicode(filename_e.text())
180 text = text.replace(".json",".csv") if v else text.replace(".csv",".json")
181 filename_e.setText(text)
183 b1.clicked.connect(lambda: set_csv(True))
184 b2.clicked.connect(lambda: set_csv(False))
186 return vbox, filename_e, b1
190 class MyTreeWidget(QTreeWidget):
191 def __init__(self, parent):
192 QTreeWidget.__init__(self, parent)
193 self.setContextMenuPolicy(Qt.CustomContextMenu)
194 self.connect(self, SIGNAL('itemActivated(QTreeWidgetItem*, int)'), self.itemactivated)
196 def itemactivated(self, item):
198 for i in range(0,self.viewport().height()/5):
199 if self.itemAt(QPoint(0,i*5)) == item:
203 for j in range(0,30):
204 if self.itemAt(QPoint(0,i*5 + j)) != item:
206 self.emit(SIGNAL('customContextMenuRequested(const QPoint&)'), QPoint(50, i*5 + j - 1))
211 if __name__ == "__main__":
212 app = QApplication([])
213 t = WaitingDialog(None, 'testing ...', lambda: [time.sleep(1)], lambda x: QMessageBox.information(None, 'done', "done", _('OK')))