mirror of
https://github.com/onionshare/onionshare.git
synced 2025-02-22 07:29:56 -05:00
Improved Documentation along with some minor code changes
This commit is contained in:
parent
8a10b8be6f
commit
c3d9fcd138
@ -27,22 +27,20 @@ from .gui_common import GuiCommon
|
|||||||
|
|
||||||
class Alert(QtWidgets.QMessageBox):
|
class Alert(QtWidgets.QMessageBox):
|
||||||
"""
|
"""
|
||||||
An alert box dialog.
|
A class to display an alert box dialog.
|
||||||
|
|
||||||
|
Args:
|
||||||
|
common: Reference to the common GUI object for logging.
|
||||||
|
message: The message to display in the alert dialog.
|
||||||
|
icon: The icon to display alongside the alert message (default: NoIcon).
|
||||||
|
buttons: Buttons to display in the alert (default: Ok).
|
||||||
|
autostart: If True, the dialog automatically opens (default: True).
|
||||||
|
title: Title of the dialog window (default: "OnionShare").
|
||||||
"""
|
"""
|
||||||
|
|
||||||
def __init__(
|
def __init__(self, common, message, icon=QtWidgets.QMessageBox.NoIcon, buttons=QtWidgets.QMessageBox.Ok, autostart=True, title="OnionShare"):
|
||||||
self,
|
super().__init__(None)
|
||||||
common,
|
|
||||||
message,
|
|
||||||
icon=QtWidgets.QMessageBox.NoIcon,
|
|
||||||
buttons=QtWidgets.QMessageBox.Ok,
|
|
||||||
autostart=True,
|
|
||||||
title="OnionShare",
|
|
||||||
):
|
|
||||||
super(Alert, self).__init__(None)
|
|
||||||
|
|
||||||
self.common = common
|
self.common = common
|
||||||
|
|
||||||
self.common.log("Alert", "__init__")
|
self.common.log("Alert", "__init__")
|
||||||
|
|
||||||
self.setWindowTitle(title)
|
self.setWindowTitle(title)
|
||||||
@ -57,17 +55,17 @@ class Alert(QtWidgets.QMessageBox):
|
|||||||
|
|
||||||
class AddFileDialog(QtWidgets.QFileDialog):
|
class AddFileDialog(QtWidgets.QFileDialog):
|
||||||
"""
|
"""
|
||||||
Overridden version of QFileDialog which allows us to select folders as well
|
Customized version of QFileDialog to allow selecting both files and folders.
|
||||||
as, or instead of, files. For adding files/folders to share.
|
|
||||||
|
|
||||||
Note that this dialog can't be used in macOS, only in Windows, Linux, and BSD.
|
Note: Not compatible with macOS due to the sandbox requiring native dialogs.
|
||||||
This is because the macOS sandbox requires native dialogs, and this is a Qt5
|
Only usable on Windows, Linux, and BSD.
|
||||||
dialog.
|
|
||||||
|
Args:
|
||||||
|
common: Reference to the common GUI object for logging.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
def __init__(self, common, *args, **kwargs):
|
def __init__(self, common, *args, **kwargs):
|
||||||
QtWidgets.QFileDialog.__init__(self, *args, **kwargs)
|
super().__init__(*args, **kwargs)
|
||||||
|
|
||||||
self.common = common
|
self.common = common
|
||||||
self.common.log("AddFileDialog", "__init__")
|
self.common.log("AddFileDialog", "__init__")
|
||||||
|
|
||||||
@ -75,30 +73,45 @@ class AddFileDialog(QtWidgets.QFileDialog):
|
|||||||
self.setOption(self.Option.ReadOnly, True)
|
self.setOption(self.Option.ReadOnly, True)
|
||||||
self.setOption(self.Option.ShowDirsOnly, False)
|
self.setOption(self.Option.ShowDirsOnly, False)
|
||||||
self.setFileMode(self.FileMode.ExistingFiles)
|
self.setFileMode(self.FileMode.ExistingFiles)
|
||||||
|
|
||||||
|
# Allow multi-selection in both tree view and list view
|
||||||
tree_view = self.findChild(QtWidgets.QTreeView)
|
tree_view = self.findChild(QtWidgets.QTreeView)
|
||||||
tree_view.setSelectionMode(QtWidgets.QAbstractItemView.ExtendedSelection)
|
tree_view.setSelectionMode(QtWidgets.QAbstractItemView.ExtendedSelection)
|
||||||
|
|
||||||
list_view = self.findChild(QtWidgets.QListView, "listView")
|
list_view = self.findChild(QtWidgets.QListView, "listView")
|
||||||
list_view.setSelectionMode(QtWidgets.QAbstractItemView.ExtendedSelection)
|
list_view.setSelectionMode(QtWidgets.QAbstractItemView.ExtendedSelection)
|
||||||
|
|
||||||
def accept(self):
|
def accept(self):
|
||||||
|
"""
|
||||||
|
Override accept to log the action before closing the dialog.
|
||||||
|
"""
|
||||||
self.common.log("AddFileDialog", "accept")
|
self.common.log("AddFileDialog", "accept")
|
||||||
QtWidgets.QDialog.accept(self)
|
super().accept()
|
||||||
|
|
||||||
|
|
||||||
class MinimumSizeWidget(QtWidgets.QWidget):
|
class MinimumSizeWidget(QtWidgets.QWidget):
|
||||||
"""
|
"""
|
||||||
An empty widget with a minimum width and height, just to force layouts to behave
|
A widget with a specified minimum width and height to force layouts to behave.
|
||||||
|
|
||||||
|
Args:
|
||||||
|
width: Minimum width of the widget.
|
||||||
|
height: Minimum height of the widget.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
def __init__(self, width, height):
|
def __init__(self, width, height):
|
||||||
super(MinimumSizeWidget, self).__init__()
|
super().__init__()
|
||||||
self.setMinimumWidth(width)
|
self.setMinimumWidth(width)
|
||||||
self.setMinimumHeight(height)
|
self.setMinimumHeight(height)
|
||||||
|
|
||||||
|
|
||||||
class Image(qrcode.image.base.BaseImage):
|
class Image(qrcode.image.base.BaseImage):
|
||||||
"""
|
"""
|
||||||
A custom Image class, for use with the QR Code pixmap.
|
Custom QR Code image class for use with PyQt pixmaps.
|
||||||
|
|
||||||
|
Args:
|
||||||
|
border: Size of the border around the QR code.
|
||||||
|
width: Width of the QR code in pixels.
|
||||||
|
box_size: Size of each box in the QR code.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
def __init__(self, border, width, box_size, *args, **kwargs):
|
def __init__(self, border, width, box_size, *args, **kwargs):
|
||||||
@ -110,9 +123,19 @@ class Image(qrcode.image.base.BaseImage):
|
|||||||
self._image.fill(QtCore.Qt.white)
|
self._image.fill(QtCore.Qt.white)
|
||||||
|
|
||||||
def pixmap(self):
|
def pixmap(self):
|
||||||
|
"""
|
||||||
|
Convert the QR code image to a QPixmap for display in the GUI.
|
||||||
|
"""
|
||||||
return QtGui.QPixmap.fromImage(self._image)
|
return QtGui.QPixmap.fromImage(self._image)
|
||||||
|
|
||||||
def drawrect(self, row, col):
|
def drawrect(self, row, col):
|
||||||
|
"""
|
||||||
|
Draw a single black rectangle (QR code module) at the specified row and column.
|
||||||
|
|
||||||
|
Args:
|
||||||
|
row: The row of the QR code matrix.
|
||||||
|
col: The column of the QR code matrix.
|
||||||
|
"""
|
||||||
painter = QtGui.QPainter(self._image)
|
painter = QtGui.QPainter(self._image)
|
||||||
painter.fillRect(
|
painter.fillRect(
|
||||||
(col + self.border) * self.box_size,
|
(col + self.border) * self.box_size,
|
||||||
@ -123,25 +146,34 @@ class Image(qrcode.image.base.BaseImage):
|
|||||||
)
|
)
|
||||||
|
|
||||||
def save(self, stream, kind=None):
|
def save(self, stream, kind=None):
|
||||||
|
"""
|
||||||
|
Empty method for compatibility with the base class.
|
||||||
|
"""
|
||||||
pass
|
pass
|
||||||
|
|
||||||
|
|
||||||
class QRCodeDialog(QtWidgets.QDialog):
|
class QRCodeDialog(QtWidgets.QDialog):
|
||||||
"""
|
"""
|
||||||
A dialog showing a QR code.
|
A dialog window to display a QR code.
|
||||||
|
|
||||||
|
Args:
|
||||||
|
common: Reference to the common GUI object for logging.
|
||||||
|
title: Title of the QR code dialog.
|
||||||
|
text: The text to encode in the QR code.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
def __init__(self, common, title, text):
|
def __init__(self, common, title, text):
|
||||||
super(QRCodeDialog, self).__init__()
|
super().__init__()
|
||||||
|
|
||||||
self.common = common
|
self.common = common
|
||||||
|
self.common.log("QRCodeDialog", "__init__")
|
||||||
|
|
||||||
self.common.log("QrCode", "__init__")
|
# QR code title label
|
||||||
|
|
||||||
self.qr_label_title = QtWidgets.QLabel(self)
|
self.qr_label_title = QtWidgets.QLabel(self)
|
||||||
self.qr_label_title.setText(title)
|
self.qr_label_title.setText(title)
|
||||||
self.qr_label_title.setAlignment(QtCore.Qt.AlignCenter)
|
self.qr_label_title.setAlignment(QtCore.Qt.AlignCenter)
|
||||||
|
|
||||||
|
# QR code image display
|
||||||
self.qr_label = QtWidgets.QLabel(self)
|
self.qr_label = QtWidgets.QLabel(self)
|
||||||
self.qr_label.setPixmap(qrcode.make(text, image_factory=Image).pixmap())
|
self.qr_label.setPixmap(qrcode.make(text, image_factory=Image).pixmap())
|
||||||
self.qr_label.setScaledContents(True)
|
self.qr_label.setScaledContents(True)
|
||||||
@ -149,6 +181,8 @@ class QRCodeDialog(QtWidgets.QDialog):
|
|||||||
|
|
||||||
self.setWindowTitle(strings._("gui_qr_code_dialog_title"))
|
self.setWindowTitle(strings._("gui_qr_code_dialog_title"))
|
||||||
self.setWindowIcon(QtGui.QIcon(GuiCommon.get_resource_path("images/logo.png")))
|
self.setWindowIcon(QtGui.QIcon(GuiCommon.get_resource_path("images/logo.png")))
|
||||||
|
|
||||||
|
# Layout for the dialog
|
||||||
layout = QtWidgets.QVBoxLayout(self)
|
layout = QtWidgets.QVBoxLayout(self)
|
||||||
layout.addWidget(self.qr_label_title)
|
layout.addWidget(self.qr_label_title)
|
||||||
layout.addWidget(self.qr_label)
|
layout.addWidget(self.qr_label)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user