QEnumComboBox#
QEnumComboBox is a variant of
QComboBox that populates the items in
the combobox based on a python Enum class.  In addition to all the methods
provided by QComboBox, this subclass adds the methods
enumClass/setEnumClass to get/set the current Enum class represented by
the combobox, and currentEnum/setCurrentEnum to get/set the current Enum
member in the combobox. There is also a new signal currentEnumChanged(enum)
analogous to currentIndexChanged and currentTextChanged.
Method like insertItem and addItem are blocked and try of its usage will end
with RuntimeError
from enum import Enum
from qtpy.QtWidgets import QApplication
from superqt import QEnumComboBox
class SampleEnum(Enum):
    first = 1
    second = 2
    third = 3
app = QApplication([])
combo = QEnumComboBox()
combo.setEnumClass(SampleEnum)
combo.show()
app.exec_()

Another option is to use optional enum_class argument of constructor and change
# option A:
combo = QEnumComboBox()
combo.setEnumClass(SampleEnum)
# option B:
combo = QEnumComboBox(enum_class=SampleEnum)
Allow None#
QEnumComboBox also allows using Optional type annotation:
from enum import Enum
from superqt import QEnumComboBox
class SampleEnum(Enum):
    first = 1
    second = 2
    third = 3
# as usual:
# you must create a QApplication before create a widget.
combo = QEnumComboBox()
combo.setEnumClass(SampleEnum, allow_none=True)
In this case there is added option ---- and the currentEnum() method will
return None when it is selected.
Qt Class#
Signals#
currentEnumChanged#
Methods#
ComboBox presenting options from a python Enum.
If the Enum class does not implement __str__ then a human readable name
is created from the name of the enum member, replacing underscores with spaces.
            currentEnum() -> Optional[EnumType]
#
    Current value as Enum member.
            enumClass() -> Optional[EnumMeta]
#
    Return current Enum class.
            isOptional() -> bool
#
    Return if current enum is with optional annotation.
            setCurrentEnum(value: Optional[EnumType]) -> None
#
    Set value with Enum.
            setEnumClass(enum: Optional[EnumMeta], allow_none=False)
#
    Set enum class from which members value should be selected.