--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/src/eric7/Plugins/VcsPlugins/vcsMercurial/HgBranchInputDialog.py Thu Jul 07 11:23:56 2022 +0200 @@ -0,0 +1,60 @@ +# -*- coding: utf-8 -*- + +# Copyright (c) 2014 - 2022 Detlev Offenbach <detlev@die-offenbachs.de> +# + +""" +Module implementing a dialog to enter the data for a branch operation. +""" + +from PyQt6.QtCore import pyqtSlot +from PyQt6.QtWidgets import QDialog, QDialogButtonBox + +from .Ui_HgBranchInputDialog import Ui_HgBranchInputDialog + + +class HgBranchInputDialog(QDialog, Ui_HgBranchInputDialog): + """ + Class implementing a dialog to enter the data for a branch operation. + """ + def __init__(self, branches, parent=None): + """ + Constructor + + @param branches branch names to populate the branch list with + (list of string) + @param parent reference to the parent widget (QWidget) + """ + super().__init__(parent) + self.setupUi(self) + + self.branchComboBox.addItems(sorted(branches)) + self.branchComboBox.setEditText("") + + self.buttonBox.button( + QDialogButtonBox.StandardButton.Ok).setEnabled(False) + + msh = self.minimumSizeHint() + self.resize(max(self.width(), msh.width()), msh.height()) + + @pyqtSlot(str) + def on_branchComboBox_editTextChanged(self, txt): + """ + Private slot handling a change of the branch name. + + @param txt contents of the branch combo box (string) + """ + self.buttonBox.button( + QDialogButtonBox.StandardButton.Ok).setEnabled(bool(txt)) + + def getData(self): + """ + Public method to get the data. + + @return tuple of branch name, a flag indicating to commit the branch + and a flag indicating to force the branch creation + @rtype tuple of (str, bool, bool) + """ + return (self.branchComboBox.currentText().replace(" ", "_"), + self.commitCheckBox.isChecked(), + self.forceCheckBox.isChecked())