mirror of
https://github.com/nqrduck/nqrduck-pulseprogrammer.git
synced 2025-01-03 05:08:10 +00:00
Refactored FileDialog. Error handling for incompatible pulse sequence.
This commit is contained in:
parent
668681cdf3
commit
06a2edc640
4 changed files with 34 additions and 58 deletions
|
@ -1,4 +1,5 @@
|
|||
"""Controller of the pulse programmer module."""
|
||||
|
||||
import logging
|
||||
import json
|
||||
import decimal
|
||||
|
@ -12,9 +13,10 @@ logger = logging.getLogger(__name__)
|
|||
|
||||
class PulseProgrammerController(ModuleController):
|
||||
"""Controller of the pulse programmer module.
|
||||
|
||||
|
||||
This class is responsible for handling the logic of the pulse programmer module.
|
||||
"""
|
||||
|
||||
def on_loading(self, pulse_parameter_options: dict) -> None:
|
||||
"""This method is called when the module is loaded. It sets the pulse parameter options in the model.
|
||||
|
||||
|
|
|
@ -1,4 +1,5 @@
|
|||
"""Model for the pulse programmer module."""
|
||||
|
||||
import logging
|
||||
from collections import OrderedDict
|
||||
from PyQt6.QtCore import pyqtSignal
|
||||
|
@ -10,21 +11,27 @@ logger = logging.getLogger(__name__)
|
|||
|
||||
class PulseProgrammerModel(ModuleModel):
|
||||
"""Model for the pulse programmer module.
|
||||
|
||||
|
||||
This class is responsible for storing the data of the pulse programmer module.
|
||||
|
||||
|
||||
Attributes:
|
||||
FILE_EXTENSION (str): The file extension for pulse programmer files.
|
||||
|
||||
Signals:
|
||||
pulse_parameter_options_changed: Emitted when the pulse parameter options change.
|
||||
events_changed: Emitted when the events in the pulse sequence change.
|
||||
pulse_sequence_changed: Emitted when the pulse sequence changes.
|
||||
"""
|
||||
|
||||
FILE_EXTENSION = "quack"
|
||||
|
||||
pulse_parameter_options_changed = pyqtSignal()
|
||||
events_changed = pyqtSignal()
|
||||
pulse_sequence_changed = pyqtSignal()
|
||||
|
||||
def __init__(self, module):
|
||||
"""Initializes the pulse programmer model.
|
||||
|
||||
|
||||
Args:
|
||||
module (Module): The module to which this model belongs.
|
||||
"""
|
||||
|
|
|
@ -1,14 +1,17 @@
|
|||
"""Initialize the PulseProgrammer module."""
|
||||
|
||||
from nqrduck.module.module import Module
|
||||
from .model import PulseProgrammerModel
|
||||
from .controller import PulseProgrammerController
|
||||
from .view import PulseProgrammerView
|
||||
|
||||
|
||||
class PulseProgrammer(Module):
|
||||
"""The pulse programmer module."""
|
||||
|
||||
def __init__(self, model, view, controller):
|
||||
"""Initializes the pulse programmer module.
|
||||
|
||||
|
||||
Args:
|
||||
model (PulseProgrammerModel): The model of the pulse programmer module.
|
||||
view (PulseProgrammerView): The view of the pulse programmer module.
|
||||
|
@ -18,4 +21,7 @@ class PulseProgrammer(Module):
|
|||
self.view = None
|
||||
self.pulse_programmer_view = view(self)
|
||||
|
||||
pulse_programmer = PulseProgrammer(PulseProgrammerModel, PulseProgrammerView, PulseProgrammerController)
|
||||
|
||||
pulse_programmer = PulseProgrammer(
|
||||
PulseProgrammerModel, PulseProgrammerView, PulseProgrammerController
|
||||
)
|
||||
|
|
|
@ -338,7 +338,7 @@ class PulseProgrammerView(ModuleView):
|
|||
def on_save_button_clicked(self) -> None:
|
||||
"""This method is called whenever the save button is clicked. It opens a dialog to select a file to save the pulse sequence to."""
|
||||
logger.debug("Save button clicked")
|
||||
file_manager = QFileManager(self)
|
||||
file_manager = self.QFileManager(self.module.model.FILE_EXTENSION, parent=self)
|
||||
file_name = file_manager.saveFileDialog()
|
||||
if file_name:
|
||||
self.module.controller.save_pulse_sequence(file_name)
|
||||
|
@ -347,10 +347,19 @@ class PulseProgrammerView(ModuleView):
|
|||
def on_load_button_clicked(self) -> None:
|
||||
"""This method is called whenever the load button is clicked. It opens a dialog to select a file to load the pulse sequence from."""
|
||||
logger.debug("Load button clicked")
|
||||
file_manager = QFileManager(self)
|
||||
file_manager = self.QFileManager(self.module.model.FILE_EXTENSION, parent=self)
|
||||
file_name = file_manager.loadFileDialog()
|
||||
if file_name:
|
||||
self.module.controller.load_pulse_sequence(file_name)
|
||||
try:
|
||||
self.module.controller.load_pulse_sequence(file_name)
|
||||
except KeyError:
|
||||
self.module.nqrduck_signal.emit(
|
||||
"notification",
|
||||
[
|
||||
"Error",
|
||||
"Error loading pulse sequence - maybe the version of the pulse sequence is not compatible?",
|
||||
],
|
||||
)
|
||||
|
||||
|
||||
class EventOptionsWidget(QWidget):
|
||||
|
@ -477,7 +486,7 @@ class EventOptionsWidget(QWidget):
|
|||
@pyqtSlot()
|
||||
def create_delete_event_dialog(self) -> None:
|
||||
"""This method is called when the delete button is clicked.
|
||||
|
||||
|
||||
It creates a dialog that asks the user if he is sure he wants to delete the event.
|
||||
If the user clicks yes, the delete_event signal is emitted.
|
||||
"""
|
||||
|
@ -615,51 +624,3 @@ class AddEventDialog(QDialog):
|
|||
return (QValidator.State.Invalid, value, position)
|
||||
|
||||
return (QValidator.State.Acceptable, value, position)
|
||||
|
||||
|
||||
# This class should be refactored in the module view so it can be used by all modules
|
||||
class QFileManager:
|
||||
"""This class provides methods for opening and saving files."""
|
||||
|
||||
def __init__(self, parent=None):
|
||||
"""Initializes the QFileManager."""
|
||||
self.parent = parent
|
||||
|
||||
def loadFileDialog(self) -> str:
|
||||
"""Opens a file dialog for the user to select a file to open.
|
||||
|
||||
Returns:
|
||||
str: The path of the file selected by the user.
|
||||
"""
|
||||
fileName, _ = QFileDialog.getOpenFileName(
|
||||
self.parent,
|
||||
"QFileManager - Open File",
|
||||
"",
|
||||
"Quack Files (*.quack);;All Files (*)",
|
||||
options=QFileDialog.Option.ReadOnly,
|
||||
)
|
||||
if fileName:
|
||||
return fileName
|
||||
else:
|
||||
return None
|
||||
|
||||
def saveFileDialog(self) -> str:
|
||||
"""Opens a file dialog for the user to select a file to save.
|
||||
|
||||
Returns:
|
||||
str: The path of the file selected by the user.
|
||||
"""
|
||||
fileName, _ = QFileDialog.getSaveFileName(
|
||||
self.parent,
|
||||
"QFileManager - Save File",
|
||||
"",
|
||||
"Quack Files (*.quack);;All Files (*)",
|
||||
options=QFileDialog.Option.DontUseNativeDialog,
|
||||
)
|
||||
if fileName:
|
||||
# Append the .quack extension if not present
|
||||
if not fileName.endswith(".quack"):
|
||||
fileName += ".quack"
|
||||
return fileName
|
||||
else:
|
||||
return None
|
||||
|
|
Loading…
Reference in a new issue