Changed to new DuckWidgets for validation.

This commit is contained in:
jupfi 2024-04-01 21:02:54 +02:00
parent 687b4100c2
commit 843f129e6e

View file

@ -4,8 +4,7 @@ import logging
import ipaddress import ipaddress
from PyQt6.QtCore import QObject, pyqtSignal, pyqtSlot from PyQt6.QtCore import QObject, pyqtSignal, pyqtSlot
from PyQt6.QtWidgets import QLineEdit, QComboBox, QCheckBox from PyQt6.QtWidgets import QLineEdit, QComboBox, QCheckBox
from PyQt6.QtGui import QValidator from nqrduck.helpers.duckwidgets import DuckFloatEdit, DuckIntEdit
from nqrduck.helpers.validators import DuckIntValidator, DuckFloatValidator
logger = logging.getLogger(__name__) logger = logging.getLogger(__name__)
@ -81,21 +80,6 @@ class Setting(QObject):
) )
return widget return widget
def update_widget_style(self):
"""Update the style of the QLineEdit widget to indicate if the value is valid."""
if (
self.validator.validate(self.widget.text(), 0)
== QValidator.State.Acceptable
):
self.widget.setStyleSheet("")
elif (
self.validator.validate(self.widget.text(), 0)
== QValidator.State.Intermediate
):
self.widget.setStyleSheet("QLineEdit { background-color: yellow; }")
else:
self.widget.setStyleSheet("QLineEdit { background-color: red; }")
class FloatSetting(Setting): class FloatSetting(Setting):
"""A setting that is a Float. """A setting that is a Float.
@ -104,7 +88,6 @@ class FloatSetting(Setting):
name (str) : The name of the setting name (str) : The name of the setting
default : The default value of the setting default : The default value of the setting
description (str) : A description of the setting description (str) : A description of the setting
validator (QValidator) : A validator for the setting
min_value : The minimum value of the setting min_value : The minimum value of the setting
max_value : The maximum value of the setting max_value : The maximum value of the setting
""" """
@ -116,23 +99,25 @@ class FloatSetting(Setting):
name: str, name: str,
default: float, default: float,
description: str, description: str,
validator: QValidator = None,
min_value: float = None, min_value: float = None,
max_value: float = None, max_value: float = None,
) -> None: ) -> None:
"""Create a new float setting.""" """Create a new float setting."""
super().__init__(name, description, default) super().__init__(name, description, default)
# If a validator is given, set it for the QLineEdit widget self.widget = DuckFloatEdit(min_value=min_value, max_value=max_value)
if validator: self.widget.setText(str(default))
self.validator = validator self.widget.state_updated.connect(self.on_state_updated)
else:
self.validator = DuckFloatValidator(self, min_value, max_value)
self.widget = self.get_widget() def on_state_updated(self, state, text):
# self.widget.setValidator(self.validator) """Update the value of the setting.
# Connect the update_widget_style method to the textChanged signal
self.widget.textChanged.connect(self.update_widget_style) Args:
state (bool): The state of the input (valid or not).
text (str): The new value of the setting.
"""
if state:
self.value = text
@property @property
def value(self): def value(self):
@ -141,15 +126,6 @@ class FloatSetting(Setting):
@value.setter @value.setter
def value(self, value): def value(self, value):
try:
if self.validator.validate(value, 0) == QValidator.State.Acceptable:
self._value = float(value)
self.settings_changed.emit()
# This should never be reached because the validator should prevent this
except ValueError:
raise ValueError("Value must be a float")
# This happens when the validator has not yet been set
except AttributeError:
self._value = float(value) self._value = float(value)
self.settings_changed.emit() self.settings_changed.emit()
@ -161,7 +137,6 @@ class IntSetting(Setting):
name (str) : The name of the setting name (str) : The name of the setting
default : The default value of the setting default : The default value of the setting
description (str) : A description of the setting description (str) : A description of the setting
validator (QValidator) : A validator for the setting
min_value : The minimum value of the setting min_value : The minimum value of the setting
max_value : The maximum value of the setting max_value : The maximum value of the setting
""" """
@ -171,25 +146,26 @@ class IntSetting(Setting):
name: str, name: str,
default: int, default: int,
description: str, description: str,
validator: QValidator = None,
min_value=None, min_value=None,
max_value=None, max_value=None,
) -> None: ) -> None:
"""Create a new int setting.""" """Create a new int setting."""
super().__init__(name, description, default) super().__init__(name, description, default)
# If a validator is given, set it for the QLineEdit widget self.widget = DuckIntEdit(min_value=min_value, max_value=max_value)
if validator: self.widget.setText(str(default))
self.validator = validator
else:
self.validator = DuckIntValidator(self, min_value, max_value)
self.widget = self.get_widget() self.widget.state_updated.connect(self.on_state_updated)
# Connect the update_widget_style method to the textChanged signal
self.widget.textChanged.connect(self.update_widget_style)
self.min_value = min_value def on_state_updated(self, state, text):
self.max_value = max_value """Update the value of the setting.
Args:
state (bool): The state of the input (valid or not).
text (str): The new value of the setting.
"""
if state:
self.value = text
@property @property
def value(self): def value(self):
@ -198,19 +174,10 @@ class IntSetting(Setting):
@value.setter @value.setter
def value(self, value): def value(self, value):
try:
if self.validator.validate(value, 0) == QValidator.State.Acceptable:
value = int(float(value)) value = int(float(value))
self._value = value self._value = value
self.settings_changed.emit() self.settings_changed.emit()
except ValueError:
raise ValueError("Value must be an int")
# This happens when the validator has not yet been set
except AttributeError as e:
logger.debug(e)
self._value = int(float(value))
self.settings_changed.emit()
class BooleanSetting(Setting): class BooleanSetting(Setting):