bec-widgets 0.82.0__tar.gz → 0.82.2__tar.gz
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/CHANGELOG.md +28 -20
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/PKG-INFO +1 -1
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/cli/client_utils.py +5 -2
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/cli/server.py +24 -10
- bec_widgets-0.82.2/bec_widgets/qt_utils/settings_dialog.py +107 -0
- {bec_widgets-0.82.0/bec_widgets/widgets/toolbar → bec_widgets-0.82.2/bec_widgets/qt_utils}/toolbar.py +1 -30
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/figure/plots/motor_map/motor_map.py +10 -8
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/motor_map/motor_map_dialog/motor_map_settings.py +4 -30
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/motor_map/motor_map_dialog/motor_map_toolbar.py +1 -1
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/motor_map/motor_map_widget.py +6 -3
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/pyproject.toml +1 -1
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/tests/unit_tests/client_mocks.py +8 -0
- bec_widgets-0.82.2/tests/unit_tests/test_client_utils.py +76 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/tests/unit_tests/test_device_input_base.py +1 -1
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/tests/unit_tests/test_device_input_widgets.py +2 -0
- bec_widgets-0.82.2/tests/unit_tests/test_motor_map_widget.py +196 -0
- bec_widgets-0.82.2/tests/unit_tests/test_msgs/__init__.py +0 -0
- bec_widgets-0.82.2/tests/unit_tests/test_rpc_server.py +42 -0
- bec_widgets-0.82.2/tests/unit_tests/test_setting_dialog.py +97 -0
- bec_widgets-0.82.0/bec_widgets/widgets/toolbar/__init__.py +0 -1
- bec_widgets-0.82.0/tests/unit_tests/test_client_utils.py +0 -29
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/.git_hooks/pre-commit +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/.gitignore +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/.gitlab/issue_templates/bug_report_template.md +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/.gitlab/issue_templates/documentation_update_template.md +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/.gitlab/issue_templates/feature_request_template.md +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/.gitlab/merge_request_templates/default.md +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/.gitlab-ci.yml +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/.pylintrc +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/.readthedocs.yaml +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/LICENSE +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/README.md +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/__init__.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/assets/bec_widgets_icon.png +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/assets/terminal_icon.png +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/cli/__init__.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/cli/auto_updates.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/cli/client.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/cli/generate_cli.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/cli/rpc_register.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/cli/rpc_wigdet_handler.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/examples/__init__.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/examples/jupyter_console/__init__.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/examples/jupyter_console/jupyter_console_window.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/examples/jupyter_console/jupyter_console_window.ui +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/examples/plugin_example_pyside/__init__.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/examples/plugin_example_pyside/main.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/examples/plugin_example_pyside/registertictactoe.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/examples/plugin_example_pyside/taskmenuextension.pyproject +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/examples/plugin_example_pyside/tictactoe.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/examples/plugin_example_pyside/tictactoeplugin.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/examples/plugin_example_pyside/tictactoetaskmenu.py +0 -0
- {bec_widgets-0.82.0/bec_widgets/widgets/base_classes → bec_widgets-0.82.2/bec_widgets/qt_utils}/__init__.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/utils/__init__.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/utils/bec_connector.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/utils/bec_designer.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/utils/bec_dispatcher.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/utils/bec_table.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/utils/bec_widget.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/utils/colors.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/utils/container_utils.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/utils/crosshair.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/utils/entry_validator.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/utils/generate_designer_plugin.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/utils/layout_manager.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/utils/plugin_templates/plugin.template +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/utils/plugin_templates/register.template +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/utils/plugin_utils.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/utils/rpc_decorator.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/utils/thread_checker.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/utils/ui_loader.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/utils/validator_delegate.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/utils/widget_io.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/utils/yaml_dialog.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/__init__.py +0 -0
- {bec_widgets-0.82.0/bec_widgets/widgets/bec_queue → bec_widgets-0.82.2/bec_widgets/widgets/base_classes}/__init__.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/base_classes/device_input_base.py +0 -0
- {bec_widgets-0.82.0/bec_widgets/widgets/bec_status_box → bec_widgets-0.82.2/bec_widgets/widgets/bec_queue}/__init__.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/bec_queue/bec_queue.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/bec_queue/bec_queue.pyproject +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/bec_queue/bec_queue_plugin.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/bec_queue/register_bec_queue.py +0 -0
- {bec_widgets-0.82.0/bec_widgets/widgets/color_button → bec_widgets-0.82.2/bec_widgets/widgets/bec_status_box}/__init__.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/bec_status_box/bec_status_box.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/bec_status_box/bec_status_box.pyproject +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/bec_status_box/bec_status_box_plugin.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/bec_status_box/register_bec_status_box.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/bec_status_box/status_item.py +0 -0
- {bec_widgets-0.82.0/bec_widgets/widgets/device_combobox → bec_widgets-0.82.2/bec_widgets/widgets/color_button}/__init__.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/color_button/assets/color_button.png +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/color_button/color_button.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/color_button/color_button.pyproject +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/color_button/color_button_plugin.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/color_button/register_color_button.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/console/console.py +0 -0
- {bec_widgets-0.82.0/bec_widgets/widgets/device_line_edit → bec_widgets-0.82.2/bec_widgets/widgets/device_combobox}/__init__.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/device_combobox/assets/device_combobox_icon.png +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/device_combobox/device_combobox.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/device_combobox/device_combobox.pyproject +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/device_combobox/device_combobox_plugin.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/device_combobox/register_device_combobox.py +0 -0
- {bec_widgets-0.82.0/bec_widgets/widgets/figure/plots → bec_widgets-0.82.2/bec_widgets/widgets/device_line_edit}/__init__.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/device_line_edit/assets/line_edit_icon.png +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/device_line_edit/device_line_edit.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/device_line_edit/device_line_edit.pyproject +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/device_line_edit/device_line_edit_plugin.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/device_line_edit/register_device_line_edit.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/dock/__init__.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/dock/dock.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/dock/dock_area.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/figure/__init__.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/figure/figure.py +0 -0
- {bec_widgets-0.82.0/bec_widgets/widgets/figure/plots/image → bec_widgets-0.82.2/bec_widgets/widgets/figure/plots}/__init__.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/figure/plots/axis_settings.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/figure/plots/axis_settings.ui +0 -0
- {bec_widgets-0.82.0/bec_widgets/widgets/figure/plots/motor_map → bec_widgets-0.82.2/bec_widgets/widgets/figure/plots/image}/__init__.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/figure/plots/image/image.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/figure/plots/image/image_item.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/figure/plots/image/image_processor.py +0 -0
- {bec_widgets-0.82.0/bec_widgets/widgets/figure/plots/waveform → bec_widgets-0.82.2/bec_widgets/widgets/figure/plots/motor_map}/__init__.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/figure/plots/plot_base.py +0 -0
- {bec_widgets-0.82.0/bec_widgets/widgets/jupyter_console → bec_widgets-0.82.2/bec_widgets/widgets/figure/plots/waveform}/__init__.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/figure/plots/waveform/waveform.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/figure/plots/waveform/waveform_curve.py +0 -0
- {bec_widgets-0.82.0/bec_widgets/widgets/motor_map → bec_widgets-0.82.2/bec_widgets/widgets/jupyter_console}/__init__.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/jupyter_console/jupyter_console.py +0 -0
- {bec_widgets-0.82.0/bec_widgets/widgets/motor_map/motor_map_dialog → bec_widgets-0.82.2/bec_widgets/widgets/motor_map}/__init__.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/motor_map/assets/connection.svg +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/motor_map/assets/history.svg +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/motor_map/assets/motor_map.png +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/motor_map/assets/settings.svg +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/motor_map/bec_motor_map_widget.pyproject +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/motor_map/bec_motor_map_widget_plugin.py +0 -0
- {bec_widgets-0.82.0/bec_widgets/widgets/stop_button → bec_widgets-0.82.2/bec_widgets/widgets/motor_map/motor_map_dialog}/__init__.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/motor_map/motor_map_dialog/motor_map_settings.ui +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/motor_map/register_bec_motor_map_widget.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/ring_progress_bar/__init__.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/ring_progress_bar/ring.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/ring_progress_bar/ring_progress_bar.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/scan_control/__init__.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/scan_control/scan_control.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/scan_control/scan_group_box.py +0 -0
- {bec_widgets-0.82.0/bec_widgets/widgets/text_box → bec_widgets-0.82.2/bec_widgets/widgets/stop_button}/__init__.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/stop_button/assets/stop.png +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/stop_button/register_stop_button.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/stop_button/stop_button.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/stop_button/stop_button.pyproject +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/stop_button/stop_button_plugin.py +0 -0
- {bec_widgets-0.82.0/bec_widgets/widgets/toggle → bec_widgets-0.82.2/bec_widgets/widgets/text_box}/__init__.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/text_box/text_box.py +0 -0
- {bec_widgets-0.82.0/bec_widgets/widgets/vscode → bec_widgets-0.82.2/bec_widgets/widgets/toggle}/__init__.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/toggle/register_toggle_switch.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/toggle/toggle.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/toggle/toggle_switch.pyproject +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/toggle/toggle_switch_plugin.py +0 -0
- {bec_widgets-0.82.0/bec_widgets/widgets/website → bec_widgets-0.82.2/bec_widgets/widgets/vscode}/__init__.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/vscode/vscode.py +0 -0
- {bec_widgets-0.82.0/tests → bec_widgets-0.82.2/bec_widgets/widgets/website}/__init__.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/website/website.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/docs/Makefile +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/docs/_static/custom.css +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/docs/_templates/custom-class-template.rst +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/docs/_templates/custom-module-template.rst +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/docs/api_reference/api_reference.md +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/docs/assets/apps_48dp.svg +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/docs/assets/display_settings_48dp.svg +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/docs/assets/index_api.svg +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/docs/assets/index_contribute.svg +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/docs/assets/index_getting_started.svg +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/docs/assets/index_user_guide.svg +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/docs/assets/rocket_launch_48dp.svg +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/docs/conf.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/docs/developer/developer.md +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/docs/developer/getting_started/development.md +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/docs/developer/getting_started/getting_started.md +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/docs/developer/widgets/widgets.md +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/docs/index.md +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/docs/introduction/introduction.md +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/docs/make.bat +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/docs/requirements.txt +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/docs/user/api_reference/api_reference.md +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/docs/user/applications/applications.md +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/docs/user/customisation.md +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/docs/user/getting_started/BECDockArea.png +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/docs/user/getting_started/auto_updates.md +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/docs/user/getting_started/getting_started.md +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/docs/user/getting_started/gui_complex_gui.gif +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/docs/user/getting_started/installation.md +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/docs/user/getting_started/quick_start.md +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/docs/user/user.md +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/docs/user/widgets/BECFigure.png +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/docs/user/widgets/bec_figure.md +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/docs/user/widgets/bec_figure_dap.gif +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/docs/user/widgets/bec_status_box.gif +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/docs/user/widgets/bec_status_box.md +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/docs/user/widgets/buttons.md +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/docs/user/widgets/image_plot.gif +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/docs/user/widgets/motor.gif +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/docs/user/widgets/progress_bar.gif +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/docs/user/widgets/ring_progress_bar.md +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/docs/user/widgets/scan_control.gif +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/docs/user/widgets/scan_control.md +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/docs/user/widgets/scatter_2D.gif +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/docs/user/widgets/text_box.md +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/docs/user/widgets/w1D.gif +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/docs/user/widgets/website.md +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/docs/user/widgets/widgets.md +0 -0
- {bec_widgets-0.82.0/tests/end-2-end → bec_widgets-0.82.2/tests}/__init__.py +0 -0
- {bec_widgets-0.82.0/tests/unit_tests → bec_widgets-0.82.2/tests/end-2-end}/__init__.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/tests/end-2-end/conftest.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/tests/end-2-end/test_bec_dock_rpc_e2e.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/tests/end-2-end/test_bec_figure_rpc_e2e.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/tests/end-2-end/test_rpc_register_e2e.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/tests/end-2-end/test_scan_control_e2e.py +0 -0
- {bec_widgets-0.82.0/tests/unit_tests/test_msgs → bec_widgets-0.82.2/tests/unit_tests}/__init__.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/tests/unit_tests/conftest.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/tests/unit_tests/test_bec_connector.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/tests/unit_tests/test_bec_dispatcher.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/tests/unit_tests/test_bec_dock.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/tests/unit_tests/test_bec_figure.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/tests/unit_tests/test_bec_image.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/tests/unit_tests/test_bec_motor_map.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/tests/unit_tests/test_bec_queue.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/tests/unit_tests/test_bec_status_box.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/tests/unit_tests/test_color_validation.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/tests/unit_tests/test_configs/config_device.yaml +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/tests/unit_tests/test_configs/config_device_no_entry.yaml +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/tests/unit_tests/test_configs/config_scan.yaml +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/tests/unit_tests/test_crosshair.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/tests/unit_tests/test_generate_cli_client.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/tests/unit_tests/test_generate_plugin.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/tests/unit_tests/test_msgs/available_scans_message.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/tests/unit_tests/test_plot_base.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/tests/unit_tests/test_plugin_utils.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/tests/unit_tests/test_ring_progress_bar.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/tests/unit_tests/test_rpc_register.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/tests/unit_tests/test_rpc_widget_handler.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/tests/unit_tests/test_scan_control.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/tests/unit_tests/test_scan_control_group_box.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/tests/unit_tests/test_stop_button.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/tests/unit_tests/test_text_box_widget.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/tests/unit_tests/test_toggle.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/tests/unit_tests/test_vscode_widget.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/tests/unit_tests/test_waveform1d.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/tests/unit_tests/test_website_widget.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/tests/unit_tests/test_widget_io.py +0 -0
- {bec_widgets-0.82.0 → bec_widgets-0.82.2}/tests/unit_tests/test_yaml_dialog.py +0 -0
@@ -1,5 +1,33 @@
|
|
1
1
|
# CHANGELOG
|
2
2
|
|
3
|
+
## v0.82.2 (2024-07-08)
|
4
|
+
|
5
|
+
### Fix
|
6
|
+
|
7
|
+
* fix(rpc_server): pass cli config to server ([`90178e2`](https://gitlab.psi.ch/bec/bec_widgets/-/commit/90178e2f61fa9dac7d82c0d0db40a9767bb133e6))
|
8
|
+
|
9
|
+
## v0.82.1 (2024-07-07)
|
10
|
+
|
11
|
+
### Fix
|
12
|
+
|
13
|
+
* fix(motor_map): bug where motors without limits were selected ([`c78cd89`](https://gitlab.psi.ch/bec/bec_widgets/-/commit/c78cd898f203f950d7cb589eb5609feaa88062cf))
|
14
|
+
|
15
|
+
### Refactor
|
16
|
+
|
17
|
+
* refactor(setting_dialog): moved to qt_utils ([`3826bb3`](https://gitlab.psi.ch/bec/bec_widgets/-/commit/3826bb3d9e870e85709b5b20ef09a4d22641280c))
|
18
|
+
|
19
|
+
* refactor(toolbar): toolbar moved from widgets to qt_utils ([`7ffc06f`](https://gitlab.psi.ch/bec/bec_widgets/-/commit/7ffc06f3c7ddd86a1681408a75221b9bbadb236b))
|
20
|
+
|
21
|
+
### Test
|
22
|
+
|
23
|
+
* test(setting_dialog): tests added ([`74a249b`](https://gitlab.psi.ch/bec/bec_widgets/-/commit/74a249bd065d01006cb532bfff2a9bfedb34b592))
|
24
|
+
|
25
|
+
### Unknown
|
26
|
+
|
27
|
+
* tests(motor_map_widget): tests added ([`734f4c7`](https://gitlab.psi.ch/bec/bec_widgets/-/commit/734f4c77507a1edafd477d81b5f7401d8e759be2))
|
28
|
+
|
29
|
+
* feat(settings_dialog):apply button ([`2020953`](https://gitlab.psi.ch/bec/bec_widgets/-/commit/2020953b933b6fcad61ecc770588d39518c26fdd))
|
30
|
+
|
3
31
|
## v0.82.0 (2024-07-07)
|
4
32
|
|
5
33
|
### Feature
|
@@ -110,12 +138,6 @@
|
|
110
138
|
|
111
139
|
## v0.77.0 (2024-07-02)
|
112
140
|
|
113
|
-
### Feature
|
114
|
-
|
115
|
-
* feat(bec_connector): export config to yaml ([`a391f30`](https://gitlab.psi.ch/bec/bec_widgets/-/commit/a391f3018c50fee6a4a06884491b957df80c3cd3))
|
116
|
-
|
117
|
-
* feat(utils): colors added convertor for rgba to hex ([`572f2fb`](https://gitlab.psi.ch/bec/bec_widgets/-/commit/572f2fb8110d5cb0e80f3ca45ce57ef405572456))
|
118
|
-
|
119
141
|
### Fix
|
120
142
|
|
121
143
|
* fix(waveform): scatter 2D brush error ([`215d59c`](https://gitlab.psi.ch/bec/bec_widgets/-/commit/215d59c8bfe7fda9aff8cec8353bef9e1ce2eca1))
|
@@ -123,17 +145,3 @@
|
|
123
145
|
* fix(figure): API cleanup ([`008a33a`](https://gitlab.psi.ch/bec/bec_widgets/-/commit/008a33a9b192473cc58e90cd6d98c5bcb5f7b8c0))
|
124
146
|
|
125
147
|
* fix(figure): if/else logic corrected in subplot_factory ([`3e78723`](https://gitlab.psi.ch/bec/bec_widgets/-/commit/3e787234c7274b0698423d7bf9a4c54ec46bad5f))
|
126
|
-
|
127
|
-
* fix(image): processing of already displayed data; closes #106 ([`1173510`](https://gitlab.psi.ch/bec/bec_widgets/-/commit/1173510105d2d70d7e498c2ac1e122cea3a16597))
|
128
|
-
|
129
|
-
* fix(bec_figure): full reconstruction with config from other bec figure ([`b6e1e20`](https://gitlab.psi.ch/bec/bec_widgets/-/commit/b6e1e20b7c8549bb092e981062329e601411dda6))
|
130
|
-
|
131
|
-
* fix(motor_map): API changes updates current visualisation; motor_map can be initialised from config ([`2e2d422`](https://gitlab.psi.ch/bec/bec_widgets/-/commit/2e2d422910685a2527a3d961a468c787f771ca44))
|
132
|
-
|
133
|
-
* fix(image): image add_custom_image fixed, closes #225 ([`f0556e4`](https://gitlab.psi.ch/bec/bec_widgets/-/commit/f0556e44113ffee66cf735aa2dd758c62cb634f4))
|
134
|
-
|
135
|
-
* fix(figure): subplot methods consolidated; added subplot factory ([`4a97105`](https://gitlab.psi.ch/bec/bec_widgets/-/commit/4a97105e4bd2ce77d72dfe5f8307dd9ee65b21b0))
|
136
|
-
|
137
|
-
* fix(image): image can be fully reconstructed from config ([`797f73c`](https://gitlab.psi.ch/bec/bec_widgets/-/commit/797f73c39aa73e07d6311f3de4baea53f6c380e0))
|
138
|
-
|
139
|
-
* fix(image_item): vrange added int for pydantic model check ([`b8f796f`](https://gitlab.psi.ch/bec/bec_widgets/-/commit/b8f796fd3fcc15641e8fc6a3ca75c344ce90fc45))
|
@@ -2,6 +2,7 @@ from __future__ import annotations
|
|
2
2
|
|
3
3
|
import importlib
|
4
4
|
import importlib.metadata as imd
|
5
|
+
import json
|
5
6
|
import os
|
6
7
|
import select
|
7
8
|
import subprocess
|
@@ -87,7 +88,7 @@ def _get_output(process, logger) -> None:
|
|
87
88
|
print(f"Error reading process output: {str(e)}")
|
88
89
|
|
89
90
|
|
90
|
-
def _start_plot_process(gui_id, gui_class, config, logger=None) -> None:
|
91
|
+
def _start_plot_process(gui_id: str, gui_class: type, config: dict | str, logger=None) -> None:
|
91
92
|
"""
|
92
93
|
Start the plot in a new process.
|
93
94
|
|
@@ -98,6 +99,8 @@ def _start_plot_process(gui_id, gui_class, config, logger=None) -> None:
|
|
98
99
|
# pylint: disable=subprocess-run-check
|
99
100
|
command = ["bec-gui-server", "--id", gui_id, "--gui_class", gui_class.__name__]
|
100
101
|
if config:
|
102
|
+
if isinstance(config, dict):
|
103
|
+
config = json.dumps(config)
|
101
104
|
command.extend(["--config", config])
|
102
105
|
|
103
106
|
env_dict = os.environ.copy()
|
@@ -190,7 +193,7 @@ class BECGuiClientMixin:
|
|
190
193
|
if self._process is None or self._process.poll() is not None:
|
191
194
|
self._start_update_script()
|
192
195
|
self._process, self._process_output_processing_thread = _start_plot_process(
|
193
|
-
self._gui_id, self.__class__, self._client._service_config.
|
196
|
+
self._gui_id, self.__class__, self._client._service_config.config
|
194
197
|
)
|
195
198
|
while not self.gui_is_alive():
|
196
199
|
print("Waiting for GUI to start...")
|
@@ -1,6 +1,7 @@
|
|
1
1
|
from __future__ import annotations
|
2
2
|
|
3
3
|
import inspect
|
4
|
+
import json
|
4
5
|
import signal
|
5
6
|
import sys
|
6
7
|
from contextlib import redirect_stderr, redirect_stdout
|
@@ -141,10 +142,30 @@ class SimpleFileLikeFromLogOutputFunc:
|
|
141
142
|
return
|
142
143
|
|
143
144
|
|
145
|
+
def _start_server(gui_id: str, gui_class: Union[BECFigure, BECDockArea], config: str | None = None):
|
146
|
+
if config:
|
147
|
+
try:
|
148
|
+
config = json.loads(config)
|
149
|
+
service_config = ServiceConfig(config=config)
|
150
|
+
except (json.JSONDecodeError, TypeError):
|
151
|
+
service_config = ServiceConfig(config_path=config)
|
152
|
+
else:
|
153
|
+
# if no config is provided, use the default config
|
154
|
+
service_config = ServiceConfig()
|
155
|
+
|
156
|
+
bec_logger.configure(
|
157
|
+
service_config.redis,
|
158
|
+
QtRedisConnector,
|
159
|
+
service_name="BECWidgetsCLIServer",
|
160
|
+
service_config=service_config.service_config,
|
161
|
+
)
|
162
|
+
server = BECWidgetsCLIServer(gui_id=gui_id, config=service_config, gui_class=gui_class)
|
163
|
+
return server
|
164
|
+
|
165
|
+
|
144
166
|
def main():
|
145
167
|
import argparse
|
146
168
|
import os
|
147
|
-
import sys
|
148
169
|
|
149
170
|
from qtpy.QtCore import QSize
|
150
171
|
from qtpy.QtGui import QIcon
|
@@ -159,7 +180,7 @@ def main():
|
|
159
180
|
type=str,
|
160
181
|
help="Name of the gui class to be rendered. Possible values: \n- BECFigure\n- BECDockArea",
|
161
182
|
)
|
162
|
-
parser.add_argument("--config", type=str, help="Config file")
|
183
|
+
parser.add_argument("--config", type=str, help="Config file or config string.")
|
163
184
|
|
164
185
|
args = parser.parse_args()
|
165
186
|
|
@@ -188,14 +209,7 @@ def main():
|
|
188
209
|
win = QMainWindow()
|
189
210
|
win.setWindowTitle("BEC Widgets")
|
190
211
|
|
191
|
-
|
192
|
-
bec_logger.configure(
|
193
|
-
service_config.redis,
|
194
|
-
QtRedisConnector,
|
195
|
-
service_name="BECWidgetsCLIServer",
|
196
|
-
service_config=service_config.service_config,
|
197
|
-
)
|
198
|
-
server = BECWidgetsCLIServer(gui_id=args.id, config=service_config, gui_class=gui_class)
|
212
|
+
server = _start_server(args.id, gui_class, args.config)
|
199
213
|
|
200
214
|
gui = server.gui
|
201
215
|
win.setCentralWidget(gui)
|
@@ -0,0 +1,107 @@
|
|
1
|
+
from qtpy.QtCore import Slot
|
2
|
+
from qtpy.QtWidgets import QDialog, QDialogButtonBox, QHBoxLayout, QPushButton, QVBoxLayout, QWidget
|
3
|
+
|
4
|
+
|
5
|
+
class SettingWidget(QWidget):
|
6
|
+
"""
|
7
|
+
Abstract class for a settings widget to enforce the implementation of the accept_changes and display_current_settings.
|
8
|
+
Can be used for toolbar actions to display the settings of a widget.
|
9
|
+
|
10
|
+
Args:
|
11
|
+
target_widget (QWidget): The widget that the settings will be taken from and applied to.
|
12
|
+
"""
|
13
|
+
|
14
|
+
def __init__(self, parent=None, *args, **kwargs):
|
15
|
+
super().__init__(parent, *args, **kwargs)
|
16
|
+
|
17
|
+
self.target_widget = None
|
18
|
+
|
19
|
+
def set_target_widget(self, target_widget: QWidget):
|
20
|
+
self.target_widget = target_widget
|
21
|
+
|
22
|
+
@Slot()
|
23
|
+
def accept_changes(self):
|
24
|
+
"""
|
25
|
+
Accepts the changes made in the settings widget and applies them to the target widget.
|
26
|
+
"""
|
27
|
+
pass
|
28
|
+
|
29
|
+
@Slot(dict)
|
30
|
+
def display_current_settings(self, config_dict: dict):
|
31
|
+
"""
|
32
|
+
Displays the current settings of the target widget in the settings widget.
|
33
|
+
|
34
|
+
Args:
|
35
|
+
config_dict(dict): The current settings of the target widget.
|
36
|
+
"""
|
37
|
+
pass
|
38
|
+
|
39
|
+
|
40
|
+
class SettingsDialog(QDialog):
|
41
|
+
"""
|
42
|
+
Dialog to display and edit the settings of a widget with accept and cancel buttons.
|
43
|
+
|
44
|
+
Args:
|
45
|
+
parent (QWidget): The parent widget of the dialog.
|
46
|
+
target_widget (QWidget): The widget that the settings will be taken from and applied to.
|
47
|
+
settings_widget (SettingWidget): The widget that will display the settings.
|
48
|
+
"""
|
49
|
+
|
50
|
+
def __init__(
|
51
|
+
self,
|
52
|
+
parent=None,
|
53
|
+
settings_widget: SettingWidget = None,
|
54
|
+
window_title: str = "Settings",
|
55
|
+
config: dict = None,
|
56
|
+
*args,
|
57
|
+
**kwargs,
|
58
|
+
):
|
59
|
+
super().__init__(parent, *args, **kwargs)
|
60
|
+
|
61
|
+
self.setModal(False)
|
62
|
+
|
63
|
+
self.setWindowTitle(window_title)
|
64
|
+
|
65
|
+
self.widget = settings_widget
|
66
|
+
self.widget.set_target_widget(parent)
|
67
|
+
if config is None:
|
68
|
+
config = parent.get_config()
|
69
|
+
|
70
|
+
self.widget.display_current_settings(config)
|
71
|
+
|
72
|
+
self.button_box = QDialogButtonBox(QDialogButtonBox.Ok | QDialogButtonBox.Cancel)
|
73
|
+
|
74
|
+
self.apply_button = QPushButton("Apply")
|
75
|
+
|
76
|
+
button_layout = QHBoxLayout()
|
77
|
+
button_layout.addWidget(self.button_box.button(QDialogButtonBox.Cancel))
|
78
|
+
button_layout.addWidget(self.apply_button)
|
79
|
+
button_layout.addWidget(self.button_box.button(QDialogButtonBox.Ok))
|
80
|
+
|
81
|
+
self.button_box.accepted.connect(self.accept)
|
82
|
+
self.button_box.rejected.connect(self.reject)
|
83
|
+
self.apply_button.clicked.connect(self.apply_changes)
|
84
|
+
|
85
|
+
self.layout = QVBoxLayout(self)
|
86
|
+
self.layout.setContentsMargins(5, 5, 5, 5)
|
87
|
+
self.layout.addWidget(self.widget)
|
88
|
+
self.layout.addLayout(button_layout)
|
89
|
+
|
90
|
+
ok_button = self.button_box.button(QDialogButtonBox.Ok)
|
91
|
+
ok_button.setDefault(True)
|
92
|
+
ok_button.setAutoDefault(True)
|
93
|
+
|
94
|
+
@Slot()
|
95
|
+
def accept(self):
|
96
|
+
"""
|
97
|
+
Accept the changes made in the settings widget and close the dialog.
|
98
|
+
"""
|
99
|
+
self.widget.accept_changes()
|
100
|
+
super().accept()
|
101
|
+
|
102
|
+
@Slot()
|
103
|
+
def apply_changes(self):
|
104
|
+
"""
|
105
|
+
Apply the changes made in the settings widget without closing the dialog.
|
106
|
+
"""
|
107
|
+
self.widget.accept_changes()
|
@@ -3,8 +3,7 @@ from collections import defaultdict
|
|
3
3
|
|
4
4
|
# pylint: disable=no-name-in-module
|
5
5
|
from qtpy.QtCore import QSize
|
6
|
-
from qtpy.
|
7
|
-
from qtpy.QtWidgets import QHBoxLayout, QLabel, QSpinBox, QToolBar, QWidget
|
6
|
+
from qtpy.QtWidgets import QToolBar, QWidget
|
8
7
|
|
9
8
|
|
10
9
|
class ToolBarAction(ABC):
|
@@ -18,34 +17,6 @@ class ToolBarAction(ABC):
|
|
18
17
|
"""
|
19
18
|
|
20
19
|
|
21
|
-
class ColumnAdjustAction(ToolBarAction):
|
22
|
-
"""Toolbar spinbox to adjust number of columns in the plot layout"""
|
23
|
-
|
24
|
-
def add_to_toolbar(self, toolbar: QToolBar, target: QWidget):
|
25
|
-
"""Creates a access history button for the toolbar.
|
26
|
-
|
27
|
-
Args:
|
28
|
-
toolbar (QToolBar): The toolbar to add the action to.
|
29
|
-
target (QWidget): The widget that the 'Access Scan History' action will be targeted.
|
30
|
-
|
31
|
-
Returns:
|
32
|
-
QAction: The 'Access Scan History' action created for the toolbar.
|
33
|
-
"""
|
34
|
-
widget = QWidget()
|
35
|
-
layout = QHBoxLayout(widget)
|
36
|
-
|
37
|
-
label = QLabel("Columns:")
|
38
|
-
spin_box = QSpinBox()
|
39
|
-
spin_box.setMinimum(1) # Set minimum value
|
40
|
-
spin_box.setMaximum(10) # Set maximum value
|
41
|
-
spin_box.setValue(target.get_column_count()) # Initial value
|
42
|
-
spin_box.valueChanged.connect(lambda value: target.set_column_count(value))
|
43
|
-
|
44
|
-
layout.addWidget(label)
|
45
|
-
layout.addWidget(spin_box)
|
46
|
-
toolbar.addWidget(widget)
|
47
|
-
|
48
|
-
|
49
20
|
class ModularToolBar(QToolBar):
|
50
21
|
"""Modular toolbar with optional automatic initialization.
|
51
22
|
Args:
|
{bec_widgets-0.82.0 → bec_widgets-0.82.2}/bec_widgets/widgets/figure/plots/motor_map/motor_map.py
RENAMED
@@ -271,11 +271,12 @@ class BECMotorMap(BECPlotBase):
|
|
271
271
|
def _swap_limit_map(self):
|
272
272
|
"""Swap the limit map."""
|
273
273
|
self.plot_item.removeItem(self.plot_components["limit_map"])
|
274
|
-
self.
|
275
|
-
self.
|
276
|
-
|
277
|
-
|
278
|
-
|
274
|
+
if self.config.signals.x.limits is not None and self.config.signals.y.limits is not None:
|
275
|
+
self.plot_components["limit_map"] = self._make_limit_map(
|
276
|
+
self.config.signals.x.limits, self.config.signals.y.limits
|
277
|
+
)
|
278
|
+
self.plot_components["limit_map"].setZValue(-1)
|
279
|
+
self.plot_item.addItem(self.plot_components["limit_map"])
|
279
280
|
|
280
281
|
def _make_motor_map(self):
|
281
282
|
"""
|
@@ -284,9 +285,10 @@ class BECMotorMap(BECPlotBase):
|
|
284
285
|
# Create limit map
|
285
286
|
motor_x_limit = self.config.signals.x.limits
|
286
287
|
motor_y_limit = self.config.signals.y.limits
|
287
|
-
|
288
|
-
|
289
|
-
|
288
|
+
if motor_x_limit is not None or motor_y_limit is not None:
|
289
|
+
self.plot_components["limit_map"] = self._make_limit_map(motor_x_limit, motor_y_limit)
|
290
|
+
self.plot_item.addItem(self.plot_components["limit_map"])
|
291
|
+
self.plot_components["limit_map"].setZValue(-1)
|
290
292
|
|
291
293
|
# Create scatter plot
|
292
294
|
scatter_size = self.config.scatter_size
|
@@ -1,19 +1,19 @@
|
|
1
1
|
import os
|
2
2
|
|
3
3
|
from qtpy.QtCore import Slot
|
4
|
-
from qtpy.QtWidgets import
|
4
|
+
from qtpy.QtWidgets import QVBoxLayout
|
5
5
|
|
6
|
+
from bec_widgets.qt_utils.settings_dialog import SettingWidget
|
6
7
|
from bec_widgets.utils import UILoader
|
7
8
|
from bec_widgets.utils.widget_io import WidgetIO
|
8
9
|
|
9
10
|
|
10
|
-
class MotorMapSettings(
|
11
|
-
def __init__(self, parent=None,
|
11
|
+
class MotorMapSettings(SettingWidget):
|
12
|
+
def __init__(self, parent=None, *args, **kwargs):
|
12
13
|
super().__init__(parent, *args, **kwargs)
|
13
14
|
current_path = os.path.dirname(__file__)
|
14
15
|
|
15
16
|
self.ui = UILoader(self).loader(os.path.join(current_path, "motor_map_settings.ui"))
|
16
|
-
self.target_widget = target_widget
|
17
17
|
|
18
18
|
self.layout = QVBoxLayout(self)
|
19
19
|
self.layout.addWidget(self.ui)
|
@@ -45,29 +45,3 @@ class MotorMapSettings(QWidget):
|
|
45
45
|
self.target_widget.set_scatter_size(scatter_size)
|
46
46
|
self.target_widget.set_background_value(background_intensity)
|
47
47
|
self.target_widget.set_color(color)
|
48
|
-
|
49
|
-
|
50
|
-
class MotorMapDialog(QDialog):
|
51
|
-
def __init__(self, parent=None, target_widget: QWidget = None, *args, **kwargs):
|
52
|
-
super().__init__(parent, *args, **kwargs)
|
53
|
-
|
54
|
-
self.setModal(False)
|
55
|
-
|
56
|
-
self.setWindowTitle("Motor Map Settings")
|
57
|
-
|
58
|
-
self.target_widget = target_widget
|
59
|
-
self.widget = MotorMapSettings(target_widget=self.target_widget)
|
60
|
-
self.widget.display_current_settings(self.target_widget._config_dict)
|
61
|
-
self.button_box = QDialogButtonBox(QDialogButtonBox.Ok | QDialogButtonBox.Cancel)
|
62
|
-
|
63
|
-
self.button_box.accepted.connect(self.accept)
|
64
|
-
self.button_box.rejected.connect(self.reject)
|
65
|
-
|
66
|
-
self.layout = QVBoxLayout(self)
|
67
|
-
self.layout.addWidget(self.widget)
|
68
|
-
self.layout.addWidget(self.button_box)
|
69
|
-
|
70
|
-
@Slot()
|
71
|
-
def accept(self):
|
72
|
-
self.widget.accept_changes()
|
73
|
-
super().accept()
|
@@ -4,8 +4,8 @@ from qtpy.QtCore import QSize
|
|
4
4
|
from qtpy.QtGui import QAction, QIcon
|
5
5
|
from qtpy.QtWidgets import QHBoxLayout, QLabel, QWidget
|
6
6
|
|
7
|
+
from bec_widgets.qt_utils.toolbar import ToolBarAction
|
7
8
|
from bec_widgets.widgets.device_combobox.device_combobox import DeviceComboBox
|
8
|
-
from bec_widgets.widgets.toolbar.toolbar import ToolBarAction
|
9
9
|
|
10
10
|
|
11
11
|
class DeviceSelectionAction(ToolBarAction):
|
@@ -4,17 +4,18 @@ import sys
|
|
4
4
|
|
5
5
|
from qtpy.QtWidgets import QVBoxLayout, QWidget
|
6
6
|
|
7
|
+
from bec_widgets.qt_utils.settings_dialog import SettingsDialog
|
8
|
+
from bec_widgets.qt_utils.toolbar import ModularToolBar
|
7
9
|
from bec_widgets.utils import BECConnector
|
8
10
|
from bec_widgets.widgets.figure import BECFigure
|
9
11
|
from bec_widgets.widgets.figure.plots.motor_map.motor_map import MotorMapConfig
|
10
|
-
from bec_widgets.widgets.motor_map.motor_map_dialog.motor_map_settings import
|
12
|
+
from bec_widgets.widgets.motor_map.motor_map_dialog.motor_map_settings import MotorMapSettings
|
11
13
|
from bec_widgets.widgets.motor_map.motor_map_dialog.motor_map_toolbar import (
|
12
14
|
ConnectAction,
|
13
15
|
DeviceSelectionAction,
|
14
16
|
ResetHistoryAction,
|
15
17
|
SettingsAction,
|
16
18
|
)
|
17
|
-
from bec_widgets.widgets.toolbar import ModularToolBar
|
18
19
|
|
19
20
|
|
20
21
|
class BECMotorMapWidget(BECConnector, QWidget):
|
@@ -92,7 +93,9 @@ class BECMotorMapWidget(BECConnector, QWidget):
|
|
92
93
|
toolbar_y.setStyleSheet("QComboBox {{ background-color: " "; }}")
|
93
94
|
|
94
95
|
def show_settings(self) -> None:
|
95
|
-
dialog =
|
96
|
+
dialog = SettingsDialog(
|
97
|
+
self, settings_widget=MotorMapSettings(), window_title="Motor Map Settings"
|
98
|
+
)
|
96
99
|
dialog.exec()
|
97
100
|
|
98
101
|
###################################
|
@@ -72,6 +72,13 @@ class FakePositioner(FakeDevice):
|
|
72
72
|
return MagicMock(get=MagicMock(return_value=self.read_value))
|
73
73
|
|
74
74
|
|
75
|
+
class Positioner(FakePositioner):
|
76
|
+
"""just placeholder for testing embeded isinstance check in DeviceCombobox"""
|
77
|
+
|
78
|
+
def __init__(self, name="test", limits=None, read_value=1.0):
|
79
|
+
super().__init__(name, limits, read_value)
|
80
|
+
|
81
|
+
|
75
82
|
class DMMock:
|
76
83
|
def __init__(self):
|
77
84
|
self.devices = DeviceContainer()
|
@@ -95,6 +102,7 @@ DEVICES = [
|
|
95
102
|
FakeDevice("bpm3a"),
|
96
103
|
FakeDevice("bpm3i"),
|
97
104
|
FakeDevice("eiger"),
|
105
|
+
Positioner("test", limits=[-10, 10], read_value=2.0),
|
98
106
|
]
|
99
107
|
|
100
108
|
|
@@ -0,0 +1,76 @@
|
|
1
|
+
from unittest import mock
|
2
|
+
|
3
|
+
import pytest
|
4
|
+
|
5
|
+
from bec_widgets.cli.client import BECFigure
|
6
|
+
from bec_widgets.cli.client_utils import BECGuiClientMixin, _start_plot_process
|
7
|
+
|
8
|
+
from .client_mocks import FakeDevice
|
9
|
+
|
10
|
+
|
11
|
+
@pytest.fixture
|
12
|
+
def cli_figure():
|
13
|
+
fig = BECFigure(gui_id="test")
|
14
|
+
with mock.patch.object(fig, "_run_rpc") as mock_rpc_call:
|
15
|
+
with mock.patch.object(fig, "gui_is_alive", return_value=True):
|
16
|
+
yield fig, mock_rpc_call
|
17
|
+
|
18
|
+
|
19
|
+
def test_rpc_call_plot(cli_figure):
|
20
|
+
fig, mock_rpc_call = cli_figure
|
21
|
+
fig.plot(x_name="samx", y_name="bpm4i")
|
22
|
+
mock_rpc_call.assert_called_with("plot", x_name="samx", y_name="bpm4i")
|
23
|
+
|
24
|
+
|
25
|
+
def test_rpc_call_accepts_device_as_input(cli_figure):
|
26
|
+
dev1 = FakeDevice("samx")
|
27
|
+
dev2 = FakeDevice("bpm4i")
|
28
|
+
fig, mock_rpc_call = cli_figure
|
29
|
+
fig.plot(x_name=dev1, y_name=dev2)
|
30
|
+
mock_rpc_call.assert_called_with("plot", x_name="samx", y_name="bpm4i")
|
31
|
+
|
32
|
+
|
33
|
+
@pytest.mark.parametrize(
|
34
|
+
"config, call_config",
|
35
|
+
[
|
36
|
+
(None, None),
|
37
|
+
("/path/to/config.yml", "/path/to/config.yml"),
|
38
|
+
({"key": "value"}, '{"key": "value"}'),
|
39
|
+
],
|
40
|
+
)
|
41
|
+
def test_client_utils_start_plot_process(config, call_config):
|
42
|
+
with mock.patch("bec_widgets.cli.client_utils.subprocess.Popen") as mock_popen:
|
43
|
+
_start_plot_process("gui_id", BECFigure, config)
|
44
|
+
command = ["bec-gui-server", "--id", "gui_id", "--gui_class", "BECFigure"]
|
45
|
+
if call_config:
|
46
|
+
command.extend(["--config", call_config])
|
47
|
+
mock_popen.assert_called_once_with(
|
48
|
+
command,
|
49
|
+
text=True,
|
50
|
+
start_new_session=True,
|
51
|
+
stdout=mock.ANY,
|
52
|
+
stderr=mock.ANY,
|
53
|
+
env=mock.ANY,
|
54
|
+
)
|
55
|
+
|
56
|
+
|
57
|
+
def test_client_utils_passes_client_config_to_server(bec_dispatcher):
|
58
|
+
"""
|
59
|
+
Test that the client config is passed to the server. This ensures that
|
60
|
+
changes to the client config (either through config files or plugins) are
|
61
|
+
reflected in the server.
|
62
|
+
"""
|
63
|
+
mixin = BECGuiClientMixin()
|
64
|
+
mixin._client = bec_dispatcher.client
|
65
|
+
mixin._gui_id = "gui_id"
|
66
|
+
mixin.gui_is_alive = mock.MagicMock()
|
67
|
+
mixin.gui_is_alive.side_effect = [True]
|
68
|
+
|
69
|
+
with mock.patch("bec_widgets.cli.client_utils._start_plot_process") as mock_start_plot:
|
70
|
+
with mock.patch.object(mixin, "_start_update_script") as mock_start_update:
|
71
|
+
mock_start_plot.return_value = [mock.MagicMock(), mock.MagicMock()]
|
72
|
+
mixin.show()
|
73
|
+
mock_start_plot.assert_called_once_with(
|
74
|
+
"gui_id", BECGuiClientMixin, mixin._client._service_config.config
|
75
|
+
)
|
76
|
+
mock_start_update.assert_called_once()
|
@@ -63,4 +63,4 @@ def test_device_input_base_get_device_list(device_input_base):
|
|
63
63
|
|
64
64
|
def test_device_input_base_get_filters(device_input_base):
|
65
65
|
filters = device_input_base.get_available_filters()
|
66
|
-
assert filters == {"FakePositioner", "FakeDevice"}
|
66
|
+
assert filters == {"FakePositioner", "FakeDevice", "Positioner"}
|
@@ -67,6 +67,7 @@ def test_device_input_combobox_init(device_input_combobox):
|
|
67
67
|
"bpm3a",
|
68
68
|
"bpm3i",
|
69
69
|
"eiger",
|
70
|
+
"test",
|
70
71
|
]
|
71
72
|
|
72
73
|
|
@@ -153,6 +154,7 @@ def test_device_input_line_edit_init(device_input_line_edit):
|
|
153
154
|
"bpm3a",
|
154
155
|
"bpm3i",
|
155
156
|
"eiger",
|
157
|
+
"test",
|
156
158
|
]
|
157
159
|
|
158
160
|
|