Plugins/VcsPlugins/vcsGit/GitBranchPushDialog.py

changeset 6020
baf6da1ae288
child 6048
82ad8ec9548c
diff -r 58ecdaf0b789 -r baf6da1ae288 Plugins/VcsPlugins/vcsGit/GitBranchPushDialog.py
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/Plugins/VcsPlugins/vcsGit/GitBranchPushDialog.py	Sun Dec 10 17:42:11 2017 +0100
@@ -0,0 +1,75 @@
+# -*- coding: utf-8 -*-
+
+# Copyright (c) 2014 - 2017 Detlev Offenbach <detlev@die-offenbachs.de>
+#
+
+"""
+Module implementing a dialog to select the data for pushing a branch.
+"""
+
+from __future__ import unicode_literals
+
+from PyQt5.QtCore import pyqtSlot
+from PyQt5.QtWidgets import QDialog, QDialogButtonBox
+
+from .Ui_GitBranchPushDialog import Ui_GitBranchPushDialog
+
+
+class GitBranchPushDialog(QDialog, Ui_GitBranchPushDialog):
+    """
+    Class implementing a dialog to select the data for pushing a branch.
+    """
+    def __init__(self, branches, remotes, delete=False, parent=None):
+        """
+        Constructor
+        
+        @param branches list of branch names (list of string)
+        @param remotes list of remote names (list of string)
+        @param delete flag indicating a delete branch action (boolean)
+        @param parent reference to the parent widget (QWidget)
+        """
+        super(GitBranchPushDialog, self).__init__(parent)
+        self.setupUi(self)
+        
+        self.__okButton = self.buttonBox.button(QDialogButtonBox.Ok)
+        
+        self.__allBranches = self.tr("<all branches>")
+        
+        if "origin" in remotes:
+            self.remoteComboBox.addItem("origin")
+            remotes.remove("origin")
+        self.remoteComboBox.addItems(sorted(remotes))
+        
+        if delete:
+            self.branchComboBox.addItem("")
+        else:
+            self.branchComboBox.addItem(self.__allBranches)
+        if "master" in branches:
+            if not delete:
+                self.branchComboBox.addItem("master")
+            branches.remove("master")
+        self.branchComboBox.addItems(sorted(branches))
+        
+        if delete:
+            self.__okButton.setEnabled(False)
+            self.branchComboBox.setEditable(True)
+    
+    @pyqtSlot(str)
+    def on_branchComboBox_editTextChanged(self, txt):
+        """
+        Private slot to handle a change of the branch name.
+        
+        @param txt branch name (string)
+        """
+        self.__okButton.setEnabled(bool(txt))
+    
+    def getData(self):
+        """
+        Public method to get the selected data.
+        
+        @return tuple of selected branch name, remote name and a flag
+            indicating all branches (tuple of two strings and a boolean)
+        """
+        return (self.branchComboBox.currentText(),
+                self.remoteComboBox.currentText(),
+                self.branchComboBox.currentText() == self.__allBranches)

eric ide

mercurial