def __init__(self, dialog_parent, dock_area): dockarea.Dock.__init__(self, "Results", size=(1500, 500)) self.dialog_parent = dialog_parent self.dock_area = dock_area grid = LayoutWidget() self.addWidget(grid) self.table = QtGui.QTableView() self.table.setSelectionMode(QtGui.QAbstractItemView.NoSelection) self.table.horizontalHeader().setResizeMode( QtGui.QHeaderView.ResizeToContents) grid.addWidget(self.table, 0, 0) add_display_box = QtGui.QGroupBox("Add display") grid.addWidget(add_display_box, 0, 1) display_grid = QtGui.QGridLayout() add_display_box.setLayout(display_grid) for n, name in enumerate(display_types.keys()): btn = QtGui.QPushButton(name) display_grid.addWidget(btn, n, 0) btn.clicked.connect(partial(self.create_dialog, name)) self.displays = dict()
def __init__(self, manager, dock, expurl): self.manager = manager self.expurl = expurl QtGui.QTreeWidget.__init__(self) self.setColumnCount(3) self.header().setStretchLastSection(False) if hasattr(self.header(), "setSectionResizeMode"): set_resize_mode = self.header().setSectionResizeMode else: set_resize_mode = self.header().setResizeMode set_resize_mode(0, QtGui.QHeaderView.ResizeToContents) set_resize_mode(1, QtGui.QHeaderView.Stretch) set_resize_mode(2, QtGui.QHeaderView.ResizeToContents) self.header().setVisible(False) self.setSelectionMode(QtGui.QAbstractItemView.NoSelection) self.setHorizontalScrollMode(QtGui.QAbstractItemView.ScrollPerPixel) self.setVerticalScrollMode(QtGui.QAbstractItemView.ScrollPerPixel) self._groups = dict() self._arg_to_entry_widgetitem = dict() arguments = self.manager.get_submission_arguments(self.expurl) if not arguments: self.addTopLevelItem(QtGui.QTreeWidgetItem(["No arguments"])) for name, argument in arguments.items(): entry = _argty_to_entry[argument["desc"]["ty"]](argument) widget_item = QtGui.QTreeWidgetItem([name]) self._arg_to_entry_widgetitem[name] = entry, widget_item if argument["group"] is None: self.addTopLevelItem(widget_item) else: self._get_group(argument["group"]).addChild(widget_item) self.setItemWidget(widget_item, 1, entry) recompute_argument = QtGui.QToolButton() recompute_argument.setToolTip("Re-run the experiment's build " "method and take the default value") recompute_argument.setIcon(QtGui.QApplication.style().standardIcon(QtGui.QStyle.SP_BrowserReload)) recompute_argument.clicked.connect(partial(self._recompute_argument_clicked, name)) fix_layout = LayoutWidget() fix_layout.addWidget(recompute_argument) self.setItemWidget(widget_item, 2, fix_layout) widget_item = QtGui.QTreeWidgetItem() self.addTopLevelItem(widget_item) recompute_arguments = QtGui.QPushButton("Recompute all arguments") recompute_arguments.setIcon(QtGui.QApplication.style().standardIcon(QtGui.QStyle.SP_BrowserReload)) recompute_arguments.setSizePolicy(QtGui.QSizePolicy.Maximum, QtGui.QSizePolicy.Maximum) recompute_arguments.clicked.connect(dock._recompute_arguments_clicked) fix_layout = LayoutWidget() fix_layout.addWidget(recompute_arguments) self.setItemWidget(widget_item, 1, fix_layout)
def __init__(self): dockarea.Dock.__init__(self, "Parameters", size=(400, 300)) grid = LayoutWidget() self.addWidget(grid) self.search = QtGui.QLineEdit() self.search.setPlaceholderText("search...") self.search.editingFinished.connect(self._search_parameters) grid.addWidget(self.search, 0, 0) self.table = QtGui.QTableView() self.table.setSelectionMode(QtGui.QAbstractItemView.NoSelection) self.table.horizontalHeader().setResizeMode( QtGui.QHeaderView.ResizeToContents) grid.addWidget(self.table, 1, 0)
def __init__(self, dialog_parent, dock_area, datasets_sub): dockarea.Dock.__init__(self, "Datasets") self.dialog_parent = dialog_parent self.dock_area = dock_area grid = LayoutWidget() self.addWidget(grid) self.search = QtGui.QLineEdit() self.search.setPlaceholderText("search...") self.search.editingFinished.connect(self._search_datasets) grid.addWidget(self.search, 0, 0) self.table = QtGui.QTreeView() self.table.setSelectionMode(QtGui.QAbstractItemView.NoSelection) self.table.header().setResizeMode(QtGui.QHeaderView.ResizeToContents) grid.addWidget(self.table, 1, 0) self.table_model = Model(dict()) datasets_sub.add_setmodel_callback(self.set_model) datasets_sub.notify_cbs.append(self.on_mod) add_display_box = QtGui.QGroupBox("Add display") grid.addWidget(add_display_box, 1, 1) display_grid = QtGui.QGridLayout() add_display_box.setLayout(display_grid) for n, name in enumerate(display_types.keys()): btn = QtGui.QPushButton(name) display_grid.addWidget(btn, n, 0) btn.clicked.connect(partial(self.create_dialog, name)) self.displays = dict()
def __init__(self): dockarea.Dock.__init__(self, "Log", size=(1000, 300)) grid = LayoutWidget() self.addWidget(grid) grid.addWidget(QtGui.QLabel("Minimum level: "), 0, 0) grid.layout.setColumnStretch(0, 0) grid.layout.setColumnStretch(1, 0) grid.layout.setColumnStretch(2, 1) self.filterbox = QtGui.QComboBox() for item in "DEBUG", "INFO", "WARNING", "ERROR", "CRITICAL": self.filterbox.addItem(item) self.filterbox.setToolTip("Display entries at or above this level") grid.addWidget(self.filterbox, 0, 1) self.filterbox.currentIndexChanged.connect(self.filter_changed) self.log = QtGui.QTableView() self.log.setSelectionMode(QtGui.QAbstractItemView.NoSelection) self.log.horizontalHeader().setResizeMode( QtGui.QHeaderView.ResizeToContents) self.log.setHorizontalScrollMode( QtGui.QAbstractItemView.ScrollPerPixel) self.log.setShowGrid(False) self.log.setTextElideMode(QtCore.Qt.ElideNone) grid.addWidget(self.log, 1, 0, colspan=3) self.scroll_at_bottom = False
def __init__(self, manager, name, log_sub): dockarea.Dock.__init__(self, name, label="Log", size=(1000, 300)) grid = LayoutWidget() self.addWidget(grid) grid.addWidget(QtGui.QLabel("Minimum level: "), 0, 0) self.filter_level = QtGui.QComboBox() self.filter_level.addItems(["DEBUG", "INFO", "WARNING", "ERROR", "CRITICAL"]) self.filter_level.setToolTip("Display entries at or above this level") grid.addWidget(self.filter_level, 0, 1) self.filter_level.currentIndexChanged.connect( self.filter_level_changed) self.filter_freetext = QtGui.QLineEdit() self.filter_freetext.setPlaceholderText("freetext filter...") self.filter_freetext.editingFinished.connect( self.filter_freetext_changed) grid.addWidget(self.filter_freetext, 0, 2) self.log = QtGui.QTableView() self.log.setSelectionMode(QtGui.QAbstractItemView.NoSelection) self.log.horizontalHeader().setResizeMode( QtGui.QHeaderView.ResizeToContents) self.log.setHorizontalScrollMode( QtGui.QAbstractItemView.ScrollPerPixel) self.log.setShowGrid(False) self.log.setTextElideMode(QtCore.Qt.ElideNone) grid.addWidget(self.log, 1, 0, colspan=4) self.scroll_at_bottom = False self.scroll_value = 0 self.log.setContextMenuPolicy(QtCore.Qt.ActionsContextMenu) newlog_action = QtGui.QAction("Create new log dock", self.log) # note the lambda, the default parameter is overriden otherwise newlog_action.triggered.connect(lambda: manager.create_new_dock()) self.log.addAction(newlog_action) log_sub.add_setmodel_callback(self.set_model)
class ScanController(LayoutWidget): def __init__(self, procdesc): LayoutWidget.__init__(self) self.stack = QtGui.QStackedWidget() self.addWidget(self.stack, 1, 0, colspan=4) self.scale = procdesc["scale"] gmin, gmax = procdesc["global_min"], procdesc["global_max"] gstep = procdesc["global_step"] unit = procdesc["unit"] ndecimals = procdesc["ndecimals"] self.v_noscan = QtGui.QDoubleSpinBox() self.v_noscan.setDecimals(ndecimals) if gmin is not None: self.v_noscan.setMinimum(gmin / self.scale) else: self.v_noscan.setMinimum(float("-inf")) if gmax is not None: self.v_noscan.setMaximum(gmax / self.scale) else: self.v_noscan.setMaximum(float("inf")) self.v_noscan.setSingleStep(gstep / self.scale) if unit: self.v_noscan.setSuffix(" " + unit) self.v_noscan_gr = LayoutWidget() self.v_noscan_gr.addWidget(QtGui.QLabel("Value:"), 0, 0) self.v_noscan_gr.addWidget(self.v_noscan, 0, 1) self.stack.addWidget(self.v_noscan_gr) self.v_linear = _Range(gmin, gmax, gstep, unit, self.scale, ndecimals) self.stack.addWidget(self.v_linear) self.v_random = _Range(gmin, gmax, gstep, unit, self.scale, ndecimals) self.stack.addWidget(self.v_random) self.v_explicit = QtGui.QLineEdit() self.v_explicit_gr = LayoutWidget() self.v_explicit_gr.addWidget(QtGui.QLabel("Sequence:"), 0, 0) self.v_explicit_gr.addWidget(self.v_explicit, 0, 1) self.stack.addWidget(self.v_explicit_gr) self.noscan = QtGui.QRadioButton("No scan") self.linear = QtGui.QRadioButton("Linear") self.random = QtGui.QRadioButton("Random") self.explicit = QtGui.QRadioButton("Explicit") radiobuttons = QtGui.QButtonGroup() for n, b in enumerate([self.noscan, self.linear, self.random, self.explicit]): self.addWidget(b, 0, n) radiobuttons.addButton(b) b.toggled.connect(self.select_page) if "default" in procdesc: self.set_argument_value(procdesc["default"]) else: self.noscan.setChecked(True) def select_page(self): if self.noscan.isChecked(): self.stack.setCurrentWidget(self.v_noscan_gr) elif self.linear.isChecked(): self.stack.setCurrentWidget(self.v_linear) elif self.random.isChecked(): self.stack.setCurrentWidget(self.v_random) elif self.explicit.isChecked(): self.stack.setCurrentWidget(self.v_explicit_gr) def get_argument_value(self): if self.noscan.isChecked(): return {"ty": "NoScan", "value": self.v_noscan.value() * self.scale} elif self.linear.isChecked(): d = {"ty": "LinearScan"} d.update(self.v_linear.get_values()) return d elif self.random.isChecked(): d = {"ty": "RandomScan"} d.update(self.v_random.get_values()) return d elif self.explicit.isChecked(): sequence = [float(x) for x in self.v_explicit.text().split()] return {"ty": "ExplicitScan", "sequence": sequence} def set_argument_value(self, d): if d["ty"] == "NoScan": self.noscan.setChecked(True) self.v_noscan.setValue(d["value"] / self.scale) elif d["ty"] == "LinearScan": self.linear.setChecked(True) self.v_linear.set_values(d["min"], d["max"], d["npoints"]) elif d["ty"] == "RandomScan": self.random.setChecked(True) self.v_random.set_values(d["min"], d["max"], d["npoints"]) elif d["ty"] == "ExplicitScan": self.explicit.setChecked(True) self.v_explicit.insert(" ".join([str(x) for x in d["sequence"]])) else: raise ValueError("Unknown scan type '{}'".format(d["ty"]))
class ScanController(LayoutWidget): def __init__(self, procdesc): LayoutWidget.__init__(self) self.stack = QtGui.QStackedWidget() self.addWidget(self.stack, 1, 0, colspan=4) gmin, gmax = procdesc["global_min"], procdesc["global_max"] gstep = procdesc["global_step"] unit = procdesc["unit"] ndecimals = procdesc["ndecimals"] self.v_noscan = QtGui.QDoubleSpinBox() self.v_noscan.setDecimals(ndecimals) if gmin is not None: self.v_noscan.setMinimum(gmin) else: self.v_noscan.setMinimum(float("-inf")) if gmax is not None: self.v_noscan.setMaximum(gmax) else: self.v_noscan.setMaximum(float("inf")) if gstep is not None: self.v_noscan.setSingleStep(gstep) if unit: self.v_noscan.setSuffix(" " + unit) self.v_noscan_gr = LayoutWidget() self.v_noscan_gr.addWidget(QtGui.QLabel("Value:"), 0, 0) self.v_noscan_gr.addWidget(self.v_noscan, 0, 1) self.stack.addWidget(self.v_noscan_gr) self.v_linear = _Range(gmin, gmax, gstep, unit, ndecimals) self.stack.addWidget(self.v_linear) self.v_random = _Range(gmin, gmax, gstep, unit, ndecimals) self.stack.addWidget(self.v_random) self.v_explicit = QtGui.QLineEdit() self.v_explicit_gr = LayoutWidget() self.v_explicit_gr.addWidget(QtGui.QLabel("Sequence:"), 0, 0) self.v_explicit_gr.addWidget(self.v_explicit, 0, 1) self.stack.addWidget(self.v_explicit_gr) self.noscan = QtGui.QRadioButton("No scan") self.linear = QtGui.QRadioButton("Linear") self.random = QtGui.QRadioButton("Random") self.explicit = QtGui.QRadioButton("Explicit") radiobuttons = QtGui.QButtonGroup() for n, b in enumerate( [self.noscan, self.linear, self.random, self.explicit]): self.addWidget(b, 0, n) radiobuttons.addButton(b) b.toggled.connect(self.select_page) if "default" in procdesc: self.set_argument_value(procdesc["default"]) else: self.noscan.setChecked(True) def select_page(self): if self.noscan.isChecked(): self.stack.setCurrentWidget(self.v_noscan_gr) elif self.linear.isChecked(): self.stack.setCurrentWidget(self.v_linear) elif self.random.isChecked(): self.stack.setCurrentWidget(self.v_random) elif self.explicit.isChecked(): self.stack.setCurrentWidget(self.v_explicit_gr) def get_argument_value(self): if self.noscan.isChecked(): return {"ty": "NoScan", "value": self.v_noscan.value()} elif self.linear.isChecked(): d = {"ty": "LinearScan"} d.update(self.v_linear.get_values()) return d elif self.random.isChecked(): d = {"ty": "RandomScan"} d.update(self.v_random.get_values()) return d elif self.explicit.isChecked(): sequence = [float(x) for x in self.v_explicit.text().split()] return {"ty": "ExplicitScan", "sequence": sequence} def set_argument_value(self, d): if d["ty"] == "NoScan": self.noscan.setChecked(True) self.v_noscan.setValue(d["value"]) elif d["ty"] == "LinearScan": self.linear.setChecked(True) self.v_linear.set_values(d["min"], d["max"], d["npoints"]) elif d["ty"] == "RandomScan": self.random.setChecked(True) self.v_random.set_values(d["min"], d["max"], d["npoints"]) elif d["ty"] == "ExplicitScan": self.explicit.setChecked(True) self.v_explicit.insert(" ".join([str(x) for x in d["sequence"]])) else: raise ValueError("Unknown scan type '{}'".format(d["ty"]))
def __init__(self, dialog_parent, status_bar, schedule_ctl): dockarea.Dock.__init__(self, "Explorer", size=(1500, 500)) self.dialog_parent = dialog_parent self.status_bar = status_bar self.schedule_ctl = schedule_ctl self.splitter = QtGui.QSplitter(QtCore.Qt.Horizontal) self.addWidget(self.splitter) grid = LayoutWidget() self.splitter.addWidget(grid) self.el = QtGui.QListView() self.el.selectionChanged = self._selection_changed self.selected_key = None grid.addWidget(self.el, 0, 0, colspan=4) self.datetime = QtGui.QDateTimeEdit() self.datetime.setDisplayFormat("MMM d yyyy hh:mm:ss") self.datetime.setCalendarPopup(True) self.datetime.setDate(QtCore.QDate.currentDate()) self.datetime.dateTimeChanged.connect(self.enable_duedate) self.datetime_en = QtGui.QCheckBox("Due date:") grid.addWidget(self.datetime_en, 1, 0) grid.addWidget(self.datetime, 1, 1) self.priority = QtGui.QSpinBox() self.priority.setRange(-99, 99) grid.addWidget(QtGui.QLabel("Priority:"), 1, 2) grid.addWidget(self.priority, 1, 3) self.pipeline = QtGui.QLineEdit() self.pipeline.setText("main") grid.addWidget(QtGui.QLabel("Pipeline:"), 2, 0) grid.addWidget(self.pipeline, 2, 1) self.flush = QtGui.QCheckBox("Flush") grid.addWidget(self.flush, 2, 2, colspan=2) submit = QtGui.QPushButton("Submit") grid.addWidget(submit, 3, 0, colspan=4) submit.clicked.connect(self.submit_clicked) self.argeditor = _ArgumentEditor(self.dialog_parent) self.splitter.addWidget(self.argeditor) self.splitter.setSizes([grid.minimumSizeHint().width(), 1000]) self.state = dict()
def __init__(self, main_window, status_bar, explist_sub, schedule_sub, schedule_ctl, repository_ctl): dockarea.Dock.__init__(self, "Explorer", size=(1500, 500)) self.main_window = main_window self.status_bar = status_bar self.schedule_sub = schedule_sub self.schedule_ctl = schedule_ctl self.splitter = QtGui.QSplitter(QtCore.Qt.Horizontal) self.addWidget(self.splitter) grid = LayoutWidget() self.splitter.addWidget(grid) self.el = QtGui.QTreeView() self.el.setHeaderHidden(True) self.el.setSelectionBehavior(QtGui.QAbstractItemView.SelectItems) self.el.selectionChanged = self._selection_changed self.selected_key = None grid.addWidget(self.el, 0, 0, colspan=4) self.datetime = QtGui.QDateTimeEdit() self.datetime.setDisplayFormat("MMM d yyyy hh:mm:ss") self.datetime.setDate(QtCore.QDate.currentDate()) self.datetime.dateTimeChanged.connect(self.enable_duedate) self.datetime_en = QtGui.QCheckBox("Due date:") grid.addWidget(self.datetime_en, 1, 0, colspan=2) grid.addWidget(self.datetime, 1, 2, colspan=2) self.pipeline = QtGui.QLineEdit() self.pipeline.setText("main") grid.addWidget(QtGui.QLabel("Pipeline:"), 2, 0, colspan=2) grid.addWidget(self.pipeline, 2, 2, colspan=2) self.priority = QtGui.QSpinBox() self.priority.setRange(-99, 99) grid.addWidget(QtGui.QLabel("Priority:"), 3, 0) grid.addWidget(self.priority, 3, 1) self.flush = QtGui.QCheckBox("Flush") self.flush.setToolTip("Flush the pipeline before starting the experiment") grid.addWidget(self.flush, 3, 2) self.log_level = QtGui.QComboBox() self.log_level.addItems(["DEBUG", "INFO", "WARNING", "ERROR", "CRITICAL"]) self.log_level.setCurrentIndex(1) self.log_level.setToolTip("Minimum level for log entry production") grid.addWidget(self.log_level, 3, 3) submit = QtGui.QPushButton("Submit") submit.setToolTip("Schedule the selected experiment (Ctrl+Return)") grid.addWidget(submit, 4, 0, colspan=4) submit.clicked.connect(self.submit_clicked) self.argeditor = _ArgumentEditor(self.main_window) self.splitter.addWidget(self.argeditor) self.splitter.setSizes([grid.minimumSizeHint().width(), 1000]) self.argeditor_states = dict() self.explist_model = Model(dict()) explist_sub.add_setmodel_callback(self.set_model) self.shortcuts = ShortcutManager(self.main_window, self) self.el.setContextMenuPolicy(QtCore.Qt.ActionsContextMenu) submit_action = QtGui.QAction("Submit", self.el) submit_action.triggered.connect(self.submit_clicked) submit_action.setShortcut("CTRL+RETURN") self.el.addAction(submit_action) reqterm_action = QtGui.QAction("Request termination of instances", self.el) reqterm_action.triggered.connect(self.request_inst_term) reqterm_action.setShortcut("CTRL+BACKSPACE") self.el.addAction(reqterm_action) sep = QtGui.QAction(self.el) sep.setSeparator(True) self.el.addAction(sep) edit_shortcuts_action = QtGui.QAction("Edit shortcuts", self.el) edit_shortcuts_action.triggered.connect(self.edit_shortcuts) self.el.addAction(edit_shortcuts_action) scan_repository_action = QtGui.QAction("(Re)scan repository HEAD", self.el) def scan_repository(): asyncio.ensure_future(repository_ctl.scan_async()) self.status_bar.showMessage("Requested repository scan") scan_repository_action.triggered.connect(scan_repository) self.el.addAction(scan_repository_action)
def __init__(self, dialog_parent, status_bar, schedule_ctl): dockarea.Dock.__init__(self, "Explorer", size=(1500, 500)) self.dialog_parent = dialog_parent self.status_bar = status_bar self.schedule_ctl = schedule_ctl self.splitter = QtGui.QSplitter(QtCore.Qt.Horizontal) self.addWidget(self.splitter) grid = LayoutWidget() self.splitter.addWidget(grid) self.el = QtGui.QListView() self.el.selectionChanged = self._selection_changed self.selected_key = None grid.addWidget(self.el, 0, 0, colspan=4) self.datetime = QtGui.QDateTimeEdit() self.datetime.setDisplayFormat("MMM d yyyy hh:mm:ss") self.datetime.setDate(QtCore.QDate.currentDate()) self.datetime.dateTimeChanged.connect(self.enable_duedate) self.datetime_en = QtGui.QCheckBox("Due date:") grid.addWidget(self.datetime_en, 1, 0, colspan=2) grid.addWidget(self.datetime, 1, 2, colspan=2) self.pipeline = QtGui.QLineEdit() self.pipeline.setText("main") grid.addWidget(QtGui.QLabel("Pipeline:"), 2, 0, colspan=2) grid.addWidget(self.pipeline, 2, 2, colspan=2) self.priority = QtGui.QSpinBox() self.priority.setRange(-99, 99) grid.addWidget(QtGui.QLabel("Priority:"), 3, 0) grid.addWidget(self.priority, 3, 1) self.flush = QtGui.QCheckBox("Flush") self.flush.setToolTip("Flush the pipeline before starting the experiment") grid.addWidget(self.flush, 3, 2) self.log_level = QtGui.QComboBox() for item in "DEBUG", "INFO", "WARNING", "ERROR", "CRITICAL": self.log_level.addItem(item) self.log_level.setCurrentIndex(1) self.log_level.setToolTip("Minimum level for log entry production") grid.addWidget(self.log_level, 3, 3) submit = QtGui.QPushButton("Submit") submit.setShortcut("CTRL+RETURN") submit.setToolTip("Schedule the selected experiment (CTRL+ENTER)") grid.addWidget(submit, 4, 0, colspan=4) submit.clicked.connect(self.submit_clicked) self.argeditor = _ArgumentEditor(self.dialog_parent) self.splitter.addWidget(self.argeditor) self.splitter.setSizes([grid.minimumSizeHint().width(), 1000]) self.state = dict()
#Layout for file options FILE_OPT_LAYOUT = LayoutWidget() FILE_OPT_GEN_BUTTON = QtGui.QPushButton('Generate FLASH Model') FILE_OPT_LOAD_BUTTON = QtGui.QPushButton('Load FLASH Model') FILE_OPT_GEN_LABEL = QtGui.QLabel() FILE_OPT_GEN_LABEL.setText( "Creates a FLASH file from an text-based instruction file.\n\n\n") FILE_OPT_LOAD_LABEL = QtGui.QLabel() FILE_OPT_LOAD_LABEL.setText( "Load a FLASH file to be displayed in the preview windows.\n\n\n") FILE_OPT_GEN_BUTTON.clicked.connect(generate_flash_file) FILE_OPT_LOAD_BUTTON.clicked.connect(load_flash_file) FILE_OPT_LAYOUT.addWidget(FILE_OPT_GEN_BUTTON, row=0, col=0) FILE_OPT_LAYOUT.addWidget(FILE_OPT_GEN_LABEL, row=1, col=0) FILE_OPT_LAYOUT.addWidget(FILE_OPT_LOAD_BUTTON, row=2, col=0) FILE_OPT_LAYOUT.addWidget(FILE_OPT_LOAD_LABEL, row=3, col=0) #Layout for preview options OPT_LAYOUT = LayoutWidget() #Add Docks in correct positions PREVIEWER.add_widget("Animated Preview", "left") # Widget 1 / -4 PREVIEWER.graphic_engine.root.add_dock("File Options", 150, 150, "left") # Widget -3 PREVIEWER.graphic_engine.root.add_to_dock(-1, FILE_OPT_LAYOUT) PREVIEWER.graphic_engine.root.add_dock("Options", 150, 150,
def __init__(self, manager, name, log_sub): dockarea.Dock.__init__(self, name, label="Log") self.setMinimumSize(QtCore.QSize(720, 250)) grid = LayoutWidget() self.addWidget(grid) grid.addWidget(QtGui.QLabel("Minimum level: "), 0, 0) self.filter_level = QtGui.QComboBox() self.filter_level.addItems(["DEBUG", "INFO", "WARNING", "ERROR", "CRITICAL"]) self.filter_level.setToolTip("Display entries at or above this level") grid.addWidget(self.filter_level, 0, 1) self.filter_level.currentIndexChanged.connect(self.filter_level_changed) self.filter_freetext = QtGui.QLineEdit() self.filter_freetext.setPlaceholderText("freetext filter...") self.filter_freetext.editingFinished.connect(self.filter_freetext_changed) grid.addWidget(self.filter_freetext, 0, 2) scrollbottom = QtGui.QToolButton() scrollbottom.setToolTip("Scroll to bottom") scrollbottom.setIcon(QtGui.QApplication.style().standardIcon(QtGui.QStyle.SP_ArrowDown)) grid.addWidget(scrollbottom, 0, 3) scrollbottom.clicked.connect(self.scroll_to_bottom) newdock = QtGui.QToolButton() newdock.setToolTip("Create new log dock") newdock.setIcon(QtGui.QApplication.style().standardIcon(QtGui.QStyle.SP_FileDialogNewFolder)) # note the lambda, the default parameter is overriden otherwise newdock.clicked.connect(lambda: manager.create_new_dock()) grid.addWidget(newdock, 0, 4) grid.layout.setColumnStretch(2, 1) self.log = QtGui.QTableView() self.log.setSelectionMode(QtGui.QAbstractItemView.NoSelection) self.log.horizontalHeader().setResizeMode(QtGui.QHeaderView.ResizeToContents) self.log.horizontalHeader().setStretchLastSection(True) self.log.verticalHeader().setResizeMode(QtGui.QHeaderView.ResizeToContents) self.log.verticalHeader().hide() self.log.setHorizontalScrollMode(QtGui.QAbstractItemView.ScrollPerPixel) self.log.setVerticalScrollMode(QtGui.QAbstractItemView.ScrollPerPixel) self.log.setShowGrid(False) self.log.setTextElideMode(QtCore.Qt.ElideNone) grid.addWidget(self.log, 1, 0, colspan=5) self.scroll_at_bottom = False self.scroll_value = 0 log_sub.add_setmodel_callback(self.set_model)
def __init__(self, dialog_parent, status_bar, schedule_ctl): dockarea.Dock.__init__(self, "Explorer", size=(1500, 500)) self.dialog_parent = dialog_parent self.status_bar = status_bar self.schedule_ctl = schedule_ctl self.splitter = QtGui.QSplitter(QtCore.Qt.Horizontal) self.addWidget(self.splitter) grid = LayoutWidget() self.splitter.addWidget(grid) self.el = QtGui.QListView() self.el.selectionChanged = self._selection_changed self.selected_key = None grid.addWidget(self.el, 0, 0, colspan=4) self.datetime = QtGui.QDateTimeEdit() self.datetime.setDisplayFormat("MMM d yyyy hh:mm:ss") self.datetime.setDate(QtCore.QDate.currentDate()) self.datetime.dateTimeChanged.connect(self.enable_duedate) self.datetime_en = QtGui.QCheckBox("Due date:") grid.addWidget(self.datetime_en, 1, 0, colspan=2) grid.addWidget(self.datetime, 1, 2, colspan=2) self.pipeline = QtGui.QLineEdit() self.pipeline.setText("main") grid.addWidget(QtGui.QLabel("Pipeline:"), 2, 0, colspan=2) grid.addWidget(self.pipeline, 2, 2, colspan=2) self.priority = QtGui.QSpinBox() self.priority.setRange(-99, 99) grid.addWidget(QtGui.QLabel("Priority:"), 3, 0) grid.addWidget(self.priority, 3, 1) self.flush = QtGui.QCheckBox("Flush") self.flush.setToolTip( "Flush the pipeline before starting the experiment") grid.addWidget(self.flush, 3, 2) self.log_level = QtGui.QComboBox() for item in "DEBUG", "INFO", "WARNING", "ERROR", "CRITICAL": self.log_level.addItem(item) self.log_level.setCurrentIndex(1) self.log_level.setToolTip("Minimum level for log entry production") grid.addWidget(self.log_level, 3, 3) submit = QtGui.QPushButton("Submit") submit.setShortcut("CTRL+RETURN") submit.setToolTip("Schedule the selected experiment (CTRL+ENTER)") grid.addWidget(submit, 4, 0, colspan=4) submit.clicked.connect(self.submit_clicked) self.argeditor = _ArgumentEditor(self.dialog_parent) self.splitter.addWidget(self.argeditor) self.splitter.setSizes([grid.minimumSizeHint().width(), 1000]) self.state = dict()
class Widget(QtGui.QWidget): def __init__(self, dcontrols, lamb_po, phas, rh, jalph, jbet, parent=None): super(Widget, self).__init__(parent=parent) self.initiate(dcontrols, lamb_po, phas, rh, jalph, jbet) def initiate(self, dcontrols, lamb_po, phas, rh, jalph, jbet): self.dcontrols = dcontrols self.layout = LayoutWidget() self.ws = [] self.ws += [Slider(0, 1, "\u03b1")] self.ws += [Slider(0, 1, "\u03b2")] # be careful, the label below affects creation of slide(int or float) self.ws += [Slider(1, 10, "\u2113")] print(self.ws[2].x) for i in range(3): self.layout.addWidget(self.ws[i], row=0, col=i) self.dcontrols.addWidget(self.layout) # ========================================================================= self.ws[0].slider.setMaximum(glo_var.slid_precision) self.ws[0].x = glo_var.alpha self.ws[0].setLabelValue(self.ws[0].x * glo_var.slid_precision) self.ws[0].slider.setValue(glo_var.alpha * glo_var.slid_precision) self.ws[0].slider.valueChanged.connect(self.ws[0].setLabelValue) self.ws[1].slider.setMaximum(glo_var.slid_precision) self.ws[1].x = glo_var.beta self.ws[1].setLabelValue(self.ws[1].x * glo_var.slid_precision) self.ws[1].slider.setValue(glo_var.beta * glo_var.slid_precision) self.ws[1].slider.valueChanged.connect(self.ws[1].setLabelValue) self.ws[2].x = glo_var.l self.ws[2].slider.setPageStep(1) self.ws[2].intsetLabelValue(self.ws[2].x) self.ws[2].slider.setValue(glo_var.l) self.ws[2].slider.valueChanged.connect(self.ws[2].intsetLabelValue) self.ws[2].slider.setMaximum(20) self.ws[2].slider.setMinimum(1) # ===================================================================================================================================== self.update_alpha_slid(self.ws[0]) self.update_beta_slid(self.ws[1]) self.update_l_slid(self.ws[2]) [ self.ws[i].slider.valueChanged.connect(self.update_ab_rh) for i in range(2) ] self.ws[2].slider.valueChanged.connect(self.update_lamb_l) self.phas = phas self.rh = rh self.jalph = jalph self.jbet = jbet self.lamb_po = lamb_po self.phas.receive(self) self.update_ab_rh() # Updates def update_lamb_rh(self, index, y, remove): glo_var.alpha = self.ws[0].x glo_var.beta = self.ws[1].x glo_var.l = self.ws[2].x if remove == 0: glo_var.lambdas[index][1] = y self.lamb_po.update() self.rh.update() self.update_alpha_slid(self.ws[0]) self.update_beta_slid(self.ws[1]) self.phas.update() self.jalph.update() self.jbet.update() def update_lamb_l(self): glo_var.alpha = self.ws[0].x glo_var.beta = self.ws[1].x glo_var.l = self.ws[2].x self.update_alpha_slid(self.ws[0]) self.update_beta_slid(self.ws[1]) # self.lamb_po.update() self.rh.update() self.phas.update() self.jalph.update() self.jbet.update() def update_phas(self, a, b): glo_var.alpha = a glo_var.beta = b self.rh.update() self.update_alpha_slid(self.ws[0]) self.update_beta_slid(self.ws[1]) self.phas.update() self.jalph.update() self.jbet.update() def update_ab_rh(self): glo_var.alpha = self.ws[0].x glo_var.beta = self.ws[1].x self.rh.update() self.phas.update() self.jalph.update() self.jbet.update() def update_l_slid(self, slid): slid.x = glo_var.l slid.spin.setValue(slid.x) slid.intsetLabelValue(slid.x) slid.slider.setValue(glo_var.l) def update_alpha_slid(self, slid): slid.slider.setMaximum(2 * glo_var.alpha_star * glo_var.slid_precision) slid.spin.setRange(0, 2 * glo_var.alpha_star) slid.x = glo_var.alpha temp = glo_var.beta slid.spin.setValue(slid.x) glo_var.beta = temp slid.setLabelValue(slid.x * glo_var.slid_precision) slid.slider.setValue(glo_var.alpha * glo_var.slid_precision) def update_beta_slid(self, slid): slid.slider.setMaximum(2 * glo_var.beta_star * glo_var.slid_precision) slid.spin.setRange(0, 2 * glo_var.beta_star) slid.x = glo_var.beta temp = glo_var.beta slid.spin.setValue(slid.x) glo_var.beta = temp slid.setLabelValue(slid.x * glo_var.slid_precision) slid.slider.setValue(glo_var.beta * glo_var.slid_precision)