mirror of
https://github.com/onionshare/onionshare.git
synced 2025-07-30 18:09:01 -04:00
FileSelection and ServerStatus interact together, disabling buttons when appropriate
This commit is contained in:
parent
db6600cb71
commit
49eac35196
3 changed files with 87 additions and 21 deletions
|
@ -6,6 +6,7 @@ from onionshare import strings, helpers
|
||||||
|
|
||||||
class FileList(QtGui.QListWidget):
|
class FileList(QtGui.QListWidget):
|
||||||
files_dropped = QtCore.pyqtSignal()
|
files_dropped = QtCore.pyqtSignal()
|
||||||
|
files_updated = QtCore.pyqtSignal()
|
||||||
|
|
||||||
def __init__(self, parent=None):
|
def __init__(self, parent=None):
|
||||||
super(FileList, self).__init__(parent)
|
super(FileList, self).__init__(parent)
|
||||||
|
@ -74,6 +75,8 @@ class FileList(QtGui.QListWidget):
|
||||||
item.setIcon(icon)
|
item.setIcon(icon)
|
||||||
self.addItem(item)
|
self.addItem(item)
|
||||||
|
|
||||||
|
self.files_updated.emit()
|
||||||
|
|
||||||
def human_readable_filesize(self, b):
|
def human_readable_filesize(self, b):
|
||||||
thresh = 1024.0
|
thresh = 1024.0
|
||||||
if b < thresh:
|
if b < thresh:
|
||||||
|
@ -89,6 +92,7 @@ class FileList(QtGui.QListWidget):
|
||||||
class FileSelection(QtGui.QVBoxLayout):
|
class FileSelection(QtGui.QVBoxLayout):
|
||||||
def __init__(self):
|
def __init__(self):
|
||||||
super(FileSelection, self).__init__()
|
super(FileSelection, self).__init__()
|
||||||
|
self.server_on = False
|
||||||
|
|
||||||
# file list
|
# file list
|
||||||
self.file_list = FileList()
|
self.file_list = FileList()
|
||||||
|
@ -114,6 +118,15 @@ class FileSelection(QtGui.QVBoxLayout):
|
||||||
self.update()
|
self.update()
|
||||||
|
|
||||||
def update(self):
|
def update(self):
|
||||||
|
# all buttons should be disabled if the server is on
|
||||||
|
if self.server_on:
|
||||||
|
self.add_files_button.setEnabled(False)
|
||||||
|
self.add_dir_button.setEnabled(False)
|
||||||
|
self.delete_button.setEnabled(False)
|
||||||
|
else:
|
||||||
|
self.add_files_button.setEnabled(True)
|
||||||
|
self.add_dir_button.setEnabled(True)
|
||||||
|
|
||||||
# delete button should be disabled if item isn't selected
|
# delete button should be disabled if item isn't selected
|
||||||
current_item = self.file_list.currentItem()
|
current_item = self.file_list.currentItem()
|
||||||
if not current_item:
|
if not current_item:
|
||||||
|
@ -143,3 +156,16 @@ class FileSelection(QtGui.QVBoxLayout):
|
||||||
self.file_list.takeItem(current_row)
|
self.file_list.takeItem(current_row)
|
||||||
self.update()
|
self.update()
|
||||||
|
|
||||||
|
def server_started(self):
|
||||||
|
self.server_on = True
|
||||||
|
self.file_list.setAcceptDrops(False)
|
||||||
|
self.update()
|
||||||
|
|
||||||
|
def server_stopped(self):
|
||||||
|
self.server_on = False
|
||||||
|
self.file_list.setAcceptDrops(True)
|
||||||
|
self.update()
|
||||||
|
|
||||||
|
def get_num_files(self):
|
||||||
|
return len(self.file_list.filenames)
|
||||||
|
|
||||||
|
|
|
@ -24,23 +24,25 @@ class Application(QtGui.QApplication):
|
||||||
QtGui.QApplication.__init__(self, sys.argv)
|
QtGui.QApplication.__init__(self, sys.argv)
|
||||||
|
|
||||||
class OnionShareGui(QtGui.QWidget):
|
class OnionShareGui(QtGui.QWidget):
|
||||||
def __init__(self, app, filenames=None):
|
def __init__(self, app):
|
||||||
super(OnionShareGui, self).__init__()
|
super(OnionShareGui, self).__init__()
|
||||||
self.app = app
|
self.app = app
|
||||||
self.filenames = filenames
|
|
||||||
|
|
||||||
self.setWindowTitle('OnionShare')
|
self.setWindowTitle('OnionShare')
|
||||||
self.setWindowIcon(window_icon)
|
self.setWindowIcon(window_icon)
|
||||||
|
|
||||||
def start_send(self):
|
def start_send(self, filenames=None):
|
||||||
# file selection
|
# file selection
|
||||||
file_selection = FileSelection()
|
file_selection = FileSelection()
|
||||||
if self.filenames:
|
if filenames:
|
||||||
for filename in self.filenames:
|
for filename in filenames:
|
||||||
file_selection.file_list.add_file(filename)
|
file_selection.file_list.add_file(filename)
|
||||||
|
|
||||||
# server status
|
# server status
|
||||||
server_status = ServerStatus()
|
server_status = ServerStatus(file_selection)
|
||||||
|
server_status.server_started.connect(file_selection.server_started)
|
||||||
|
server_status.server_stopped.connect(file_selection.server_stopped)
|
||||||
|
file_selection.file_list.files_updated.connect(server_status.update)
|
||||||
|
|
||||||
# downloads
|
# downloads
|
||||||
downloads = Downloads()
|
downloads = Downloads()
|
||||||
|
@ -366,8 +368,8 @@ def main():
|
||||||
qtapp.connect(qtapp, QtCore.SIGNAL("aboutToQuit()"), shutdown)
|
qtapp.connect(qtapp, QtCore.SIGNAL("aboutToQuit()"), shutdown)
|
||||||
|
|
||||||
# launch the gui
|
# launch the gui
|
||||||
gui = OnionShareGui(app, filenames)
|
gui = OnionShareGui(app)
|
||||||
gui.start_send()
|
gui.start_send(filenames)
|
||||||
|
|
||||||
# all done
|
# all done
|
||||||
sys.exit(qtapp.exec_())
|
sys.exit(qtapp.exec_())
|
||||||
|
|
|
@ -4,28 +4,39 @@ import common
|
||||||
from onionshare import strings, helpers
|
from onionshare import strings, helpers
|
||||||
|
|
||||||
class ServerStatus(QtGui.QVBoxLayout):
|
class ServerStatus(QtGui.QVBoxLayout):
|
||||||
def __init__(self):
|
server_started = QtCore.pyqtSignal()
|
||||||
|
server_stopped = QtCore.pyqtSignal()
|
||||||
|
|
||||||
|
STATUS_STOPPED = 0
|
||||||
|
STATUS_WORKING = 1
|
||||||
|
STATUS_STARTED = 2
|
||||||
|
|
||||||
|
def __init__(self, file_selection):
|
||||||
super(ServerStatus, self).__init__()
|
super(ServerStatus, self).__init__()
|
||||||
|
self.status = self.STATUS_STOPPED
|
||||||
self.addSpacing(10)
|
self.addSpacing(10)
|
||||||
|
|
||||||
|
self.file_selection = file_selection
|
||||||
|
|
||||||
# server layout
|
# server layout
|
||||||
self.status_image = QtGui.QImage('{0}/server_stopped.png'.format(common.onionshare_gui_dir))
|
self.status_image_stopped = QtGui.QImage('{0}/server_stopped.png'.format(common.onionshare_gui_dir))
|
||||||
status_image_label = QtGui.QLabel()
|
self.status_image_working = QtGui.QImage('{0}/server_working.png'.format(common.onionshare_gui_dir))
|
||||||
status_image_label.setPixmap(QtGui.QPixmap.fromImage(self.status_image))
|
self.status_image_started = QtGui.QImage('{0}/server_started.png'.format(common.onionshare_gui_dir))
|
||||||
status_image_label.setFixedWidth(30)
|
self.status_image_label = QtGui.QLabel()
|
||||||
|
self.status_image_label.setFixedWidth(30)
|
||||||
self.start_server_button = QtGui.QPushButton(strings._('gui_start_server'))
|
self.start_server_button = QtGui.QPushButton(strings._('gui_start_server'))
|
||||||
self.start_server_button.clicked.connect(self.start_server)
|
self.start_server_button.clicked.connect(self.start_server)
|
||||||
self.stop_server_button = QtGui.QPushButton(strings._('gui_stop_server'))
|
self.stop_server_button = QtGui.QPushButton(strings._('gui_stop_server'))
|
||||||
self.stop_server_button.clicked.connect(self.stop_server)
|
self.stop_server_button.clicked.connect(self.stop_server)
|
||||||
server_layout = QtGui.QHBoxLayout()
|
server_layout = QtGui.QHBoxLayout()
|
||||||
server_layout.addWidget(status_image_label)
|
server_layout.addWidget(self.status_image_label)
|
||||||
server_layout.addWidget(self.start_server_button)
|
server_layout.addWidget(self.start_server_button)
|
||||||
server_layout.addWidget(self.stop_server_button)
|
server_layout.addWidget(self.stop_server_button)
|
||||||
|
|
||||||
# url layout
|
# url layout
|
||||||
url_font = QtGui.QFont()
|
url_font = QtGui.QFont()
|
||||||
url_font.setPointSize(8)
|
url_font.setPointSize(8)
|
||||||
self.url_label = QtGui.QLabel('http://mry2aqolyzxwfxpt.onion/ x6justoparr5ayreqj6zyf6w2e')
|
self.url_label = QtGui.QLabel()
|
||||||
self.url_label.setFont(url_font)
|
self.url_label.setFont(url_font)
|
||||||
self.url_label.setWordWrap(True)
|
self.url_label.setWordWrap(True)
|
||||||
self.url_label.setAlignment(QtCore.Qt.AlignCenter)
|
self.url_label.setAlignment(QtCore.Qt.AlignCenter)
|
||||||
|
@ -43,11 +54,38 @@ class ServerStatus(QtGui.QVBoxLayout):
|
||||||
self.addLayout(server_layout)
|
self.addLayout(server_layout)
|
||||||
self.addLayout(url_layout)
|
self.addLayout(url_layout)
|
||||||
|
|
||||||
|
self.update()
|
||||||
|
|
||||||
|
def update(self):
|
||||||
|
# set the status image
|
||||||
|
if self.status == self.STATUS_STOPPED:
|
||||||
|
self.status_image_label.setPixmap(QtGui.QPixmap.fromImage(self.status_image_stopped))
|
||||||
|
elif self.status == self.STATUS_WORKING:
|
||||||
|
self.status_image_label.setPixmap(QtGui.QPixmap.fromImage(self.status_image_working))
|
||||||
|
elif self.status == self.STATUS_STARTED:
|
||||||
|
self.status_image_label.setPixmap(QtGui.QPixmap.fromImage(self.status_image_started))
|
||||||
|
|
||||||
|
# buttons enabled
|
||||||
|
if self.file_selection.get_num_files() == 0:
|
||||||
|
self.start_server_button.setEnabled(False)
|
||||||
|
self.stop_server_button.setEnabled(False)
|
||||||
|
else:
|
||||||
|
if self.status == self.STATUS_STOPPED:
|
||||||
|
self.start_server_button.setEnabled(True)
|
||||||
|
self.stop_server_button.setEnabled(False)
|
||||||
|
else:
|
||||||
|
self.start_server_button.setEnabled(False)
|
||||||
|
self.stop_server_button.setEnabled(True)
|
||||||
|
|
||||||
def start_server(self):
|
def start_server(self):
|
||||||
pass
|
self.status = self.STATUS_WORKING
|
||||||
|
self.update()
|
||||||
|
self.server_started.emit()
|
||||||
|
|
||||||
def stop_server(self):
|
def stop_server(self):
|
||||||
pass
|
self.status = self.STATUS_STOPPED
|
||||||
|
self.update()
|
||||||
|
self.server_stopped.emit()
|
||||||
|
|
||||||
def copy_url(self):
|
def copy_url(self):
|
||||||
pass
|
pass
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue