src/eric7/Plugins/VcsPlugins/vcsMercurial/HgBranchInputDialog.py

branch
eric7
changeset 9209
b99e7fd55fd3
parent 8881
54e42bc2437a
child 9221
bf71ee032bb4
diff -r 3fc8dfeb6ebe -r b99e7fd55fd3 src/eric7/Plugins/VcsPlugins/vcsMercurial/HgBranchInputDialog.py
--- /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())

eric ide

mercurial