schrodinger.ui.qt.mapperwidgets.param_editor module¶
- class schrodinger.ui.qt.mapperwidgets.param_editor.ParamEditor(param=None, *args, **kwargs)¶
- Bases: - schrodinger.models.mappers.TargetMixin,- schrodinger.ui.qt.basewidgets.BaseWidget- __init__(param=None, *args, **kwargs)¶
 - initSetUp()¶
- Creates widget from - uiand stores it- ui_widget.- Suggested subclass use: create and initialize subwidgets, and connect signals. 
 - initLayOut()¶
- Create a vertical layout for the widget ( - widget_layout) and populate it with two vertical sub-layouts:- main_layoutand- bottom_layout.- If the user has specified the - uidata member, insert the resultant- ui_widgetinto- main_layout.- If the widget already has a layout defined, this method will produce a warning (but not a traceback). - main_layoutand- bottom_layoutwill be inserted into the existing widget layout, which will not be the same as- widget_layout. It is therefore recommended that this mixin is used only with widgets that do not already have a layout.- Suggested subclass use: create, initialize, and populate layouts. 
 - setParam(param)¶
 - targetGetValue()¶
 - targetSetValue(value)¶
 
- class schrodinger.ui.qt.mapperwidgets.param_editor.DynamicTypeDelegate(*args, **kwargs)¶
- Bases: - schrodinger.ui.qt.delegates.AbstractDelegateWithEditIcon- Delegate for displaying and editing the value of a param. - This delegate changes behavior depending on the param type for that given cell. For example, a bool param will display an interactable checkbox, while a string param will display text that can be edited with a line edit. - paint(self, painter: Optional[QPainter], option: QStyleOptionViewItem, index: QModelIndex)¶
 - editorEvent(self, event: Optional[QEvent], model: Optional[QAbstractItemModel], option: QStyleOptionViewItem, index: QModelIndex) bool¶
 - createEditor(self, parent: Optional[QWidget], option: QStyleOptionViewItem, index: QModelIndex) Optional[QWidget]¶
 - setEditorData(self, editor: Optional[QWidget], index: QModelIndex)¶
 - helpEvent(self, event: Optional[QHelpEvent], view: Optional[QAbstractItemView], option: QStyleOptionViewItem, index: QModelIndex) bool¶
 - setModelData(self, editor: Optional[QWidget], model: Optional[QAbstractItemModel], index: QModelIndex)¶
 
- class schrodinger.ui.qt.mapperwidgets.param_editor.Coord(*args, _param_type=<object object>, **kwargs)¶
- Bases: - schrodinger.models.parameters.CompoundParam- w: str¶
- Base class for all Param classes. A Param is a descriptor for storing data, which means that a single Param instance will manage the data values for multiple instances of the class that owns it. Example: - class Coord(CompoundParam): x: int y: int - An instance of the Coord class can be created normally, and Params can be accessed as normal attributes: - coord = Coord() coord.x = 4 - When a Param value is set, the - valueChangedsignal is emitted. Params can be serialized and deserialized to and from JSON. Params can also be nested:- class Atom(CompoundParam): coord: Coord element: str 
 - x: float¶
- Base class for all Param classes. A Param is a descriptor for storing data, which means that a single Param instance will manage the data values for multiple instances of the class that owns it. Example: - class Coord(CompoundParam): x: int y: int - An instance of the Coord class can be created normally, and Params can be accessed as normal attributes: - coord = Coord() coord.x = 4 - When a Param value is set, the - valueChangedsignal is emitted. Params can be serialized and deserialized to and from JSON. Params can also be nested:- class Atom(CompoundParam): coord: Coord element: str 
 - y: int¶
- Base class for all Param classes. A Param is a descriptor for storing data, which means that a single Param instance will manage the data values for multiple instances of the class that owns it. Example: - class Coord(CompoundParam): x: int y: int - An instance of the Coord class can be created normally, and Params can be accessed as normal attributes: - coord = Coord() coord.x = 4 - When a Param value is set, the - valueChangedsignal is emitted. Params can be serialized and deserialized to and from JSON. Params can also be nested:- class Atom(CompoundParam): coord: Coord element: str 
 - z: bool¶
- Base class for all Param classes. A Param is a descriptor for storing data, which means that a single Param instance will manage the data values for multiple instances of the class that owns it. Example: - class Coord(CompoundParam): x: int y: int - An instance of the Coord class can be created normally, and Params can be accessed as normal attributes: - coord = Coord() coord.x = 4 - When a Param value is set, the - valueChangedsignal is emitted. Params can be serialized and deserialized to and from JSON. Params can also be nested:- class Atom(CompoundParam): coord: Coord element: str 
 - wChanged¶
- pyqtSignal(*types, name: str = …, revision: int = …, arguments: Sequence = …) -> PYQT_SIGNAL - types is normally a sequence of individual types. Each type is either a type object or a string that is the name of a C++ type. Alternatively each type could itself be a sequence of types each describing a different overloaded signal. name is the optional C++ name of the signal. If it is not specified then the name of the class attribute that is bound to the signal is used. revision is the optional revision of the signal that is exported to QML. If it is not specified then 0 is used. arguments is the optional sequence of the names of the signal’s arguments. 
 - wReplaced¶
- pyqtSignal(*types, name: str = …, revision: int = …, arguments: Sequence = …) -> PYQT_SIGNAL - types is normally a sequence of individual types. Each type is either a type object or a string that is the name of a C++ type. Alternatively each type could itself be a sequence of types each describing a different overloaded signal. name is the optional C++ name of the signal. If it is not specified then the name of the class attribute that is bound to the signal is used. revision is the optional revision of the signal that is exported to QML. If it is not specified then 0 is used. arguments is the optional sequence of the names of the signal’s arguments. 
 - xChanged¶
- pyqtSignal(*types, name: str = …, revision: int = …, arguments: Sequence = …) -> PYQT_SIGNAL - types is normally a sequence of individual types. Each type is either a type object or a string that is the name of a C++ type. Alternatively each type could itself be a sequence of types each describing a different overloaded signal. name is the optional C++ name of the signal. If it is not specified then the name of the class attribute that is bound to the signal is used. revision is the optional revision of the signal that is exported to QML. If it is not specified then 0 is used. arguments is the optional sequence of the names of the signal’s arguments. 
 - xReplaced¶
- pyqtSignal(*types, name: str = …, revision: int = …, arguments: Sequence = …) -> PYQT_SIGNAL - types is normally a sequence of individual types. Each type is either a type object or a string that is the name of a C++ type. Alternatively each type could itself be a sequence of types each describing a different overloaded signal. name is the optional C++ name of the signal. If it is not specified then the name of the class attribute that is bound to the signal is used. revision is the optional revision of the signal that is exported to QML. If it is not specified then 0 is used. arguments is the optional sequence of the names of the signal’s arguments. 
 - yChanged¶
- pyqtSignal(*types, name: str = …, revision: int = …, arguments: Sequence = …) -> PYQT_SIGNAL - types is normally a sequence of individual types. Each type is either a type object or a string that is the name of a C++ type. Alternatively each type could itself be a sequence of types each describing a different overloaded signal. name is the optional C++ name of the signal. If it is not specified then the name of the class attribute that is bound to the signal is used. revision is the optional revision of the signal that is exported to QML. If it is not specified then 0 is used. arguments is the optional sequence of the names of the signal’s arguments. 
 - yReplaced¶
- pyqtSignal(*types, name: str = …, revision: int = …, arguments: Sequence = …) -> PYQT_SIGNAL - types is normally a sequence of individual types. Each type is either a type object or a string that is the name of a C++ type. Alternatively each type could itself be a sequence of types each describing a different overloaded signal. name is the optional C++ name of the signal. If it is not specified then the name of the class attribute that is bound to the signal is used. revision is the optional revision of the signal that is exported to QML. If it is not specified then 0 is used. arguments is the optional sequence of the names of the signal’s arguments. 
 - zChanged¶
- pyqtSignal(*types, name: str = …, revision: int = …, arguments: Sequence = …) -> PYQT_SIGNAL - types is normally a sequence of individual types. Each type is either a type object or a string that is the name of a C++ type. Alternatively each type could itself be a sequence of types each describing a different overloaded signal. name is the optional C++ name of the signal. If it is not specified then the name of the class attribute that is bound to the signal is used. revision is the optional revision of the signal that is exported to QML. If it is not specified then 0 is used. arguments is the optional sequence of the names of the signal’s arguments. 
 - zReplaced¶
- pyqtSignal(*types, name: str = …, revision: int = …, arguments: Sequence = …) -> PYQT_SIGNAL - types is normally a sequence of individual types. Each type is either a type object or a string that is the name of a C++ type. Alternatively each type could itself be a sequence of types each describing a different overloaded signal. name is the optional C++ name of the signal. If it is not specified then the name of the class attribute that is bound to the signal is used. revision is the optional revision of the signal that is exported to QML. If it is not specified then 0 is used. arguments is the optional sequence of the names of the signal’s arguments. 
 
- class schrodinger.ui.qt.mapperwidgets.param_editor.MyEnum(value, names=None, *, module=None, qualname=None, type=None, start=1, boundary=None)¶
- Bases: - enum.Enum- A = 1¶
 - B = 2¶
 - C = 3¶
 
- class schrodinger.ui.qt.mapperwidgets.param_editor.Atom(*args, _param_type=<object object>, **kwargs)¶
- Bases: - schrodinger.models.parameters.CompoundParam- test_dict: Dict¶
- A Param to represent dictionaries. Values of this param will have a - mutatedsignal that will be emitted whenever any mutation method is called.- The constructor optionally takes a - value_classkeyword argument to specify what type of class the values will be. This information will be used for jsonifying the dictionary if specified. (Note that non-string keys are not currently supported for jsonification. This may change in the future. See PANEL-13029).
 - test_list: List¶
- A Param to represent lists. Values of this param will have a - mutatedsignal that will be emitted whenever any mutation method is called.- The constructor optionally takes a - item_classkeyword argument to specify what type of class the items in the list will be. This information will be used for jsonifying the list if specified.
 - mass: float¶
- Base class for all Param classes. A Param is a descriptor for storing data, which means that a single Param instance will manage the data values for multiple instances of the class that owns it. Example: - class Coord(CompoundParam): x: int y: int - An instance of the Coord class can be created normally, and Params can be accessed as normal attributes: - coord = Coord() coord.x = 4 - When a Param value is set, the - valueChangedsignal is emitted. Params can be serialized and deserialized to and from JSON. Params can also be nested:- class Atom(CompoundParam): coord: Coord element: str 
 - coordChanged¶
- pyqtSignal(*types, name: str = …, revision: int = …, arguments: Sequence = …) -> PYQT_SIGNAL - types is normally a sequence of individual types. Each type is either a type object or a string that is the name of a C++ type. Alternatively each type could itself be a sequence of types each describing a different overloaded signal. name is the optional C++ name of the signal. If it is not specified then the name of the class attribute that is bound to the signal is used. revision is the optional revision of the signal that is exported to QML. If it is not specified then 0 is used. arguments is the optional sequence of the names of the signal’s arguments. 
 - coordReplaced¶
- pyqtSignal(*types, name: str = …, revision: int = …, arguments: Sequence = …) -> PYQT_SIGNAL - types is normally a sequence of individual types. Each type is either a type object or a string that is the name of a C++ type. Alternatively each type could itself be a sequence of types each describing a different overloaded signal. name is the optional C++ name of the signal. If it is not specified then the name of the class attribute that is bound to the signal is used. revision is the optional revision of the signal that is exported to QML. If it is not specified then 0 is used. arguments is the optional sequence of the names of the signal’s arguments. 
 - massChanged¶
- pyqtSignal(*types, name: str = …, revision: int = …, arguments: Sequence = …) -> PYQT_SIGNAL - types is normally a sequence of individual types. Each type is either a type object or a string that is the name of a C++ type. Alternatively each type could itself be a sequence of types each describing a different overloaded signal. name is the optional C++ name of the signal. If it is not specified then the name of the class attribute that is bound to the signal is used. revision is the optional revision of the signal that is exported to QML. If it is not specified then 0 is used. arguments is the optional sequence of the names of the signal’s arguments. 
 - massReplaced¶
- pyqtSignal(*types, name: str = …, revision: int = …, arguments: Sequence = …) -> PYQT_SIGNAL - types is normally a sequence of individual types. Each type is either a type object or a string that is the name of a C++ type. Alternatively each type could itself be a sequence of types each describing a different overloaded signal. name is the optional C++ name of the signal. If it is not specified then the name of the class attribute that is bound to the signal is used. revision is the optional revision of the signal that is exported to QML. If it is not specified then 0 is used. arguments is the optional sequence of the names of the signal’s arguments. 
 - test_dictChanged¶
- pyqtSignal(*types, name: str = …, revision: int = …, arguments: Sequence = …) -> PYQT_SIGNAL - types is normally a sequence of individual types. Each type is either a type object or a string that is the name of a C++ type. Alternatively each type could itself be a sequence of types each describing a different overloaded signal. name is the optional C++ name of the signal. If it is not specified then the name of the class attribute that is bound to the signal is used. revision is the optional revision of the signal that is exported to QML. If it is not specified then 0 is used. arguments is the optional sequence of the names of the signal’s arguments. 
 - test_dictReplaced¶
- pyqtSignal(*types, name: str = …, revision: int = …, arguments: Sequence = …) -> PYQT_SIGNAL - types is normally a sequence of individual types. Each type is either a type object or a string that is the name of a C++ type. Alternatively each type could itself be a sequence of types each describing a different overloaded signal. name is the optional C++ name of the signal. If it is not specified then the name of the class attribute that is bound to the signal is used. revision is the optional revision of the signal that is exported to QML. If it is not specified then 0 is used. arguments is the optional sequence of the names of the signal’s arguments. 
 - test_enum2Changed¶
- pyqtSignal(*types, name: str = …, revision: int = …, arguments: Sequence = …) -> PYQT_SIGNAL - types is normally a sequence of individual types. Each type is either a type object or a string that is the name of a C++ type. Alternatively each type could itself be a sequence of types each describing a different overloaded signal. name is the optional C++ name of the signal. If it is not specified then the name of the class attribute that is bound to the signal is used. revision is the optional revision of the signal that is exported to QML. If it is not specified then 0 is used. arguments is the optional sequence of the names of the signal’s arguments. 
 - test_enum2Replaced¶
- pyqtSignal(*types, name: str = …, revision: int = …, arguments: Sequence = …) -> PYQT_SIGNAL - types is normally a sequence of individual types. Each type is either a type object or a string that is the name of a C++ type. Alternatively each type could itself be a sequence of types each describing a different overloaded signal. name is the optional C++ name of the signal. If it is not specified then the name of the class attribute that is bound to the signal is used. revision is the optional revision of the signal that is exported to QML. If it is not specified then 0 is used. arguments is the optional sequence of the names of the signal’s arguments. 
 - test_enumChanged¶
- pyqtSignal(*types, name: str = …, revision: int = …, arguments: Sequence = …) -> PYQT_SIGNAL - types is normally a sequence of individual types. Each type is either a type object or a string that is the name of a C++ type. Alternatively each type could itself be a sequence of types each describing a different overloaded signal. name is the optional C++ name of the signal. If it is not specified then the name of the class attribute that is bound to the signal is used. revision is the optional revision of the signal that is exported to QML. If it is not specified then 0 is used. arguments is the optional sequence of the names of the signal’s arguments. 
 - test_enumReplaced¶
- pyqtSignal(*types, name: str = …, revision: int = …, arguments: Sequence = …) -> PYQT_SIGNAL - types is normally a sequence of individual types. Each type is either a type object or a string that is the name of a C++ type. Alternatively each type could itself be a sequence of types each describing a different overloaded signal. name is the optional C++ name of the signal. If it is not specified then the name of the class attribute that is bound to the signal is used. revision is the optional revision of the signal that is exported to QML. If it is not specified then 0 is used. arguments is the optional sequence of the names of the signal’s arguments. 
 - test_listChanged¶
- pyqtSignal(*types, name: str = …, revision: int = …, arguments: Sequence = …) -> PYQT_SIGNAL - types is normally a sequence of individual types. Each type is either a type object or a string that is the name of a C++ type. Alternatively each type could itself be a sequence of types each describing a different overloaded signal. name is the optional C++ name of the signal. If it is not specified then the name of the class attribute that is bound to the signal is used. revision is the optional revision of the signal that is exported to QML. If it is not specified then 0 is used. arguments is the optional sequence of the names of the signal’s arguments. 
 - test_listReplaced¶
- pyqtSignal(*types, name: str = …, revision: int = …, arguments: Sequence = …) -> PYQT_SIGNAL - types is normally a sequence of individual types. Each type is either a type object or a string that is the name of a C++ type. Alternatively each type could itself be a sequence of types each describing a different overloaded signal. name is the optional C++ name of the signal. If it is not specified then the name of the class attribute that is bound to the signal is used. revision is the optional revision of the signal that is exported to QML. If it is not specified then 0 is used. arguments is the optional sequence of the names of the signal’s arguments. 
 
- schrodinger.ui.qt.mapperwidgets.param_editor.main()¶