mirror of
https://github.com/onionshare/onionshare.git
synced 2025-01-03 19:51:05 -05:00
Merge branch 'mig5-604_fix_file_list_widgets_and_ordering' into ux-update
This commit is contained in:
commit
93f6661801
@ -81,20 +81,18 @@ class FileList(QtWidgets.QListWidget):
|
|||||||
self.setSortingEnabled(True)
|
self.setSortingEnabled(True)
|
||||||
self.setMinimumHeight(205)
|
self.setMinimumHeight(205)
|
||||||
self.setSelectionMode(QtWidgets.QAbstractItemView.ExtendedSelection)
|
self.setSelectionMode(QtWidgets.QAbstractItemView.ExtendedSelection)
|
||||||
|
|
||||||
self.filenames = []
|
|
||||||
|
|
||||||
self.drop_here_image = DropHereLabel(self, True)
|
self.drop_here_image = DropHereLabel(self, True)
|
||||||
self.drop_here_text = DropHereLabel(self, False)
|
self.drop_here_text = DropHereLabel(self, False)
|
||||||
self.drop_count = DropCountLabel(self)
|
self.drop_count = DropCountLabel(self)
|
||||||
self.resizeEvent(None)
|
self.resizeEvent(None)
|
||||||
|
self.setVerticalScrollBarPolicy(QtCore.Qt.ScrollBarAlwaysOn)
|
||||||
|
|
||||||
def update(self):
|
def update(self):
|
||||||
"""
|
"""
|
||||||
Update the GUI elements based on the current state.
|
Update the GUI elements based on the current state.
|
||||||
"""
|
"""
|
||||||
# file list should have a background image if empty
|
# file list should have a background image if empty
|
||||||
if len(self.filenames) == 0:
|
if self.count() == 0:
|
||||||
self.drop_here_image.show()
|
self.drop_here_image.show()
|
||||||
self.drop_here_text.show()
|
self.drop_here_text.show()
|
||||||
else:
|
else:
|
||||||
@ -136,6 +134,15 @@ class FileList(QtWidgets.QListWidget):
|
|||||||
self.takeItem(self.row(item))
|
self.takeItem(self.row(item))
|
||||||
self.update()
|
self.update()
|
||||||
|
|
||||||
|
# Extend any filenames that were truncated to fit the window
|
||||||
|
# We use 200 as a rough guess at how wide the 'file size + delete button' widget is
|
||||||
|
# and extend based on the overall width minus that amount.
|
||||||
|
for index in range(self.count()):
|
||||||
|
metrics = QtGui.QFontMetrics(self.item(index).font())
|
||||||
|
elided = metrics.elidedText(self.item(index).basename, QtCore.Qt.ElideRight, self.width() - 200)
|
||||||
|
self.item(index).setText(elided)
|
||||||
|
|
||||||
|
|
||||||
def dragEnterEvent(self, event):
|
def dragEnterEvent(self, event):
|
||||||
"""
|
"""
|
||||||
dragEnterEvent for dragging files and directories into the widget.
|
dragEnterEvent for dragging files and directories into the widget.
|
||||||
@ -193,17 +200,16 @@ class FileList(QtWidgets.QListWidget):
|
|||||||
"""
|
"""
|
||||||
Add a file or directory to this widget.
|
Add a file or directory to this widget.
|
||||||
"""
|
"""
|
||||||
if filename not in self.filenames:
|
filenames = []
|
||||||
|
for index in range(self.count()):
|
||||||
|
filenames.append(self.item(index).filename)
|
||||||
|
|
||||||
|
if filename not in filenames:
|
||||||
if not os.access(filename, os.R_OK):
|
if not os.access(filename, os.R_OK):
|
||||||
Alert(strings._("not_a_readable_file", True).format(filename))
|
Alert(strings._("not_a_readable_file", True).format(filename))
|
||||||
return
|
return
|
||||||
|
|
||||||
self.filenames.append(filename)
|
|
||||||
# Re-sort the list internally
|
|
||||||
self.filenames.sort()
|
|
||||||
|
|
||||||
fileinfo = QtCore.QFileInfo(filename)
|
fileinfo = QtCore.QFileInfo(filename)
|
||||||
basename = os.path.basename(filename.rstrip('/'))
|
|
||||||
ip = QtWidgets.QFileIconProvider()
|
ip = QtWidgets.QFileIconProvider()
|
||||||
icon = ip.icon(fileinfo)
|
icon = ip.icon(fileinfo)
|
||||||
|
|
||||||
@ -219,18 +225,20 @@ class FileList(QtWidgets.QListWidget):
|
|||||||
item.setIcon(icon)
|
item.setIcon(icon)
|
||||||
item.size_bytes = size_bytes
|
item.size_bytes = size_bytes
|
||||||
|
|
||||||
# Item's name and size labels
|
# Item's filename attribute and size labels
|
||||||
item_name = QtWidgets.QLabel(basename)
|
item.filename = filename
|
||||||
item_name.setWordWrap(False)
|
|
||||||
item_name.setSizePolicy(QtWidgets.QSizePolicy.Ignored, QtWidgets.QSizePolicy.Fixed)
|
|
||||||
item_name.setStyleSheet('QLabel { color: #000000; font-size: 13px; }')
|
|
||||||
item_size = QtWidgets.QLabel(size_readable)
|
item_size = QtWidgets.QLabel(size_readable)
|
||||||
item_size.setStyleSheet('QLabel { color: #666666; font-size: 11px; }')
|
item_size.setStyleSheet('QLabel { color: #666666; font-size: 11px; }')
|
||||||
|
|
||||||
|
item.basename = os.path.basename(filename.rstrip('/'))
|
||||||
|
# Use the basename as the method with which to sort the list
|
||||||
|
metrics = QtGui.QFontMetrics(item.font())
|
||||||
|
elided = metrics.elidedText(item.basename, QtCore.Qt.ElideRight, self.sizeHint().width())
|
||||||
|
item.setData(QtCore.Qt.DisplayRole, elided)
|
||||||
|
|
||||||
# Item's delete button
|
# Item's delete button
|
||||||
def delete_item():
|
def delete_item():
|
||||||
itemrow = self.row(item)
|
itemrow = self.row(item)
|
||||||
self.filenames.pop(itemrow)
|
|
||||||
self.takeItem(itemrow)
|
self.takeItem(itemrow)
|
||||||
self.files_updated.emit()
|
self.files_updated.emit()
|
||||||
|
|
||||||
@ -241,13 +249,18 @@ class FileList(QtWidgets.QListWidget):
|
|||||||
item.item_button.clicked.connect(delete_item)
|
item.item_button.clicked.connect(delete_item)
|
||||||
item.item_button.setSizePolicy(QtWidgets.QSizePolicy.Fixed, QtWidgets.QSizePolicy.Fixed)
|
item.item_button.setSizePolicy(QtWidgets.QSizePolicy.Fixed, QtWidgets.QSizePolicy.Fixed)
|
||||||
|
|
||||||
|
# Item info widget, with a white background
|
||||||
|
item_info_layout = QtWidgets.QHBoxLayout()
|
||||||
|
item_info_layout.addWidget(item_size)
|
||||||
|
item_info_layout.addWidget(item.item_button)
|
||||||
|
item_info = QtWidgets.QWidget()
|
||||||
|
item_info.setObjectName('item-info')
|
||||||
|
item_info.setLayout(item_info_layout)
|
||||||
|
|
||||||
# Create the item's widget and layouts
|
# Create the item's widget and layouts
|
||||||
item_vlayout = QtWidgets.QVBoxLayout()
|
|
||||||
item_vlayout.addWidget(item_name)
|
|
||||||
item_vlayout.addWidget(item_size)
|
|
||||||
item_hlayout = QtWidgets.QHBoxLayout()
|
item_hlayout = QtWidgets.QHBoxLayout()
|
||||||
item_hlayout.addLayout(item_vlayout)
|
item_hlayout.addStretch()
|
||||||
item_hlayout.addWidget(item.item_button)
|
item_hlayout.addWidget(item_info)
|
||||||
widget = QtWidgets.QWidget()
|
widget = QtWidgets.QWidget()
|
||||||
widget.setLayout(item_hlayout)
|
widget.setLayout(item_hlayout)
|
||||||
|
|
||||||
@ -330,7 +343,6 @@ class FileSelection(QtWidgets.QVBoxLayout):
|
|||||||
selected = self.file_list.selectedItems()
|
selected = self.file_list.selectedItems()
|
||||||
for item in selected:
|
for item in selected:
|
||||||
itemrow = self.file_list.row(item)
|
itemrow = self.file_list.row(item)
|
||||||
self.file_list.filenames.pop(itemrow)
|
|
||||||
self.file_list.takeItem(itemrow)
|
self.file_list.takeItem(itemrow)
|
||||||
self.file_list.files_updated.emit()
|
self.file_list.files_updated.emit()
|
||||||
|
|
||||||
@ -357,7 +369,7 @@ class FileSelection(QtWidgets.QVBoxLayout):
|
|||||||
"""
|
"""
|
||||||
Returns the total number of files and folders in the list.
|
Returns the total number of files and folders in the list.
|
||||||
"""
|
"""
|
||||||
return len(self.file_list.filenames)
|
return len(range(self.count()))
|
||||||
|
|
||||||
def setFocus(self):
|
def setFocus(self):
|
||||||
"""
|
"""
|
||||||
|
@ -410,8 +410,11 @@ class OnionShareGui(QtWidgets.QMainWindow):
|
|||||||
|
|
||||||
# add progress bar to the status bar, indicating the crunching of files.
|
# add progress bar to the status bar, indicating the crunching of files.
|
||||||
self._zip_progress_bar = ZipProgressBar(0)
|
self._zip_progress_bar = ZipProgressBar(0)
|
||||||
self._zip_progress_bar.total_files_size = OnionShareGui._compute_total_size(
|
self.filenames = []
|
||||||
self.file_selection.file_list.filenames)
|
for index in range(self.file_selection.file_list.count()):
|
||||||
|
self.filenames.append(self.file_selection.file_list.item(index).filename)
|
||||||
|
|
||||||
|
self._zip_progress_bar.total_files_size = OnionShareGui._compute_total_size(self.filenames)
|
||||||
self.status_bar.insertWidget(0, self._zip_progress_bar)
|
self.status_bar.insertWidget(0, self._zip_progress_bar)
|
||||||
|
|
||||||
# prepare the files for sending in a new thread
|
# prepare the files for sending in a new thread
|
||||||
@ -421,7 +424,7 @@ class OnionShareGui(QtWidgets.QMainWindow):
|
|||||||
if self._zip_progress_bar != None:
|
if self._zip_progress_bar != None:
|
||||||
self._zip_progress_bar.update_processed_size_signal.emit(x)
|
self._zip_progress_bar.update_processed_size_signal.emit(x)
|
||||||
try:
|
try:
|
||||||
web.set_file_info(self.file_selection.file_list.filenames, processed_size_callback=_set_processed_size)
|
web.set_file_info(self.filenames, processed_size_callback=_set_processed_size)
|
||||||
self.app.cleanup_filenames.append(web.zip_filename)
|
self.app.cleanup_filenames.append(web.zip_filename)
|
||||||
self.starting_server_step3.emit()
|
self.starting_server_step3.emit()
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user