|
@ -150,45 +150,47 @@ class ElectrumGui(MessageBoxMixin): |
|
|
self.show_warning(str(e)) |
|
|
self.show_warning(str(e)) |
|
|
return |
|
|
return |
|
|
action = wallet.get_action() |
|
|
action = wallet.get_action() |
|
|
# run wizard |
|
|
|
|
|
if action is not None: |
|
|
if action is not None: |
|
|
wizard = InstallWizard(self.app, self.config, self.network, storage) |
|
|
return self.install_wizard(storage, action) |
|
|
wallet = wizard.run(action) |
|
|
|
|
|
# keep current wallet |
|
|
|
|
|
if not wallet: |
|
|
|
|
|
return |
|
|
|
|
|
else: |
|
|
|
|
|
wallet.start_threads(self.network) |
|
|
|
|
|
|
|
|
|
|
|
return wallet |
|
|
wallet.start_threads(self.network) |
|
|
|
|
|
return self.create_window_for_wallet(wallet) |
|
|
|
|
|
|
|
|
|
|
|
def install_wizard(self, storage, action): |
|
|
|
|
|
wizard = InstallWizard(self.app, self.config, self.network, storage) |
|
|
|
|
|
wallet = wizard.run(action) |
|
|
|
|
|
return self.create_window_for_wallet(wallet) |
|
|
|
|
|
|
|
|
def new_window(self, path, uri=None): |
|
|
def new_window(self, path, uri=None): |
|
|
# Use a signal as can be called from daemon thread |
|
|
# Use a signal as can be called from daemon thread |
|
|
self.app.emit(SIGNAL('new_window'), path, uri) |
|
|
self.app.emit(SIGNAL('new_window'), path, uri) |
|
|
|
|
|
|
|
|
|
|
|
def create_window_for_wallet(self, wallet): |
|
|
|
|
|
if not wallet: |
|
|
|
|
|
return |
|
|
|
|
|
w = ElectrumWindow(self, wallet) |
|
|
|
|
|
w.connect_slots(self.timer) |
|
|
|
|
|
w.update_recently_visited(wallet.storage.path) |
|
|
|
|
|
# initial configuration |
|
|
|
|
|
if self.config.get('hide_gui') is True and self.tray.isVisible(): |
|
|
|
|
|
w.hide() |
|
|
|
|
|
else: |
|
|
|
|
|
w.show() |
|
|
|
|
|
self.windows.append(w) |
|
|
|
|
|
self.build_tray_menu() |
|
|
|
|
|
run_hook('on_new_window', w) |
|
|
|
|
|
return w |
|
|
|
|
|
|
|
|
def start_new_window(self, path, uri): |
|
|
def start_new_window(self, path, uri): |
|
|
for w in self.windows: |
|
|
for w in self.windows: |
|
|
if w.wallet.storage.path == path: |
|
|
if w.wallet.storage.path == path: |
|
|
w.bring_to_top() |
|
|
w.bring_to_top() |
|
|
break |
|
|
break |
|
|
else: |
|
|
else: |
|
|
wallet = self.load_wallet_file(path) |
|
|
w = self.load_wallet_file(path) |
|
|
if not wallet: |
|
|
|
|
|
return |
|
|
|
|
|
w = ElectrumWindow(self, wallet) |
|
|
|
|
|
w.connect_slots(self.timer) |
|
|
|
|
|
# add to recently visited |
|
|
|
|
|
w.update_recently_visited(path) |
|
|
|
|
|
# initial configuration |
|
|
|
|
|
if self.config.get('hide_gui') is True and self.tray.isVisible(): |
|
|
|
|
|
w.hide() |
|
|
|
|
|
else: |
|
|
|
|
|
w.show() |
|
|
|
|
|
self.windows.append(w) |
|
|
|
|
|
self.build_tray_menu() |
|
|
|
|
|
run_hook('on_new_window', w) |
|
|
|
|
|
|
|
|
|
|
|
if uri: |
|
|
if uri and w: |
|
|
w.pay_to_URI(uri) |
|
|
w.pay_to_URI(uri) |
|
|
|
|
|
|
|
|
return w |
|
|
return w |
|
|