Project/UserPropertiesDialog.py

changeset 0
de9c2efb9d02
child 7
c679fb30c8f3
diff -r 000000000000 -r de9c2efb9d02 Project/UserPropertiesDialog.py
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/Project/UserPropertiesDialog.py	Mon Dec 28 16:03:33 2009 +0000
@@ -0,0 +1,95 @@
+# -*- coding: utf-8 -*-
+
+# Copyright (c) 2006 - 2009 Detlev Offenbach <detlev@die-offenbachs.de>
+#
+
+"""
+Module implementing the user specific project properties dialog.
+"""
+
+from PyQt4.QtCore import *
+from PyQt4.QtGui import *
+
+from E4Gui.E4Application import e4App
+
+import Preferences
+
+from Ui_UserPropertiesDialog import Ui_UserPropertiesDialog
+
+class UserPropertiesDialog(QDialog, Ui_UserPropertiesDialog):
+    """
+    Class implementing the user specific project properties dialog.
+    """
+    def __init__(self, project, parent = None, name = None):
+        """
+        Constructor
+        
+        @param project reference to the project object
+        @param parent parent widget of this dialog (QWidget)
+        @param name name of this dialog (string)
+        """
+        QDialog.__init__(self, parent)
+        if name:
+            self.setObjectName(name)
+        self.setupUi(self)
+        
+        self.project = project
+        
+        if self.project.pudata["VCSSTATUSMONITORINTERVAL"]:
+            self.vcsStatusMonitorIntervalSpinBox.setValue(
+                self.project.pudata["VCSSTATUSMONITORINTERVAL"][0])
+        else:
+            self.vcsStatusMonitorIntervalSpinBox.setValue(
+                Preferences.getVCS("StatusMonitorInterval"))
+        
+        enableVcsGroup = False
+        if self.project.pdata["VCS"]:
+            found = False
+            for indicator, vcsData in e4App().getObject("PluginManager")\
+                                             .getVcsSystemIndicators().items():
+                for vcsSystem, vcsSystemDisplay in vcsData:
+                    if vcsSystem == self.project.pdata["VCS"][0]:
+                        found = True
+                        break
+                
+                if found:
+                    for vcsSystem, vcsSystemDisplay in vcsData:
+                        self.vcsInterfaceCombo.addItem(vcsSystemDisplay, 
+                                                       QVariant(vcsSystem))
+                    enableVcsGroup = len(vcsData) > 1
+                    break
+        self.vcsGroup.setEnabled(enableVcsGroup)
+        
+        if self.vcsGroup.isEnabled():
+            if self.project.pudata["VCSOVERRIDE"]:
+                vcsSystem = self.project.pudata["VCSOVERRIDE"][0]
+            else:
+                vcsSystem = self.project.pdata["VCS"][0]
+            index = self.vcsInterfaceCombo.findData(QVariant(vcsSystem))
+            if index == -1:
+                index = 0
+            self.vcsInterfaceCombo.setCurrentIndex(index)
+
+    def storeData(self):
+        """
+        Public method to store the entered/modified data.
+        """
+        vcsStatusMonitorInterval = self.vcsStatusMonitorIntervalSpinBox.value()
+        if vcsStatusMonitorInterval != Preferences.getVCS("StatusMonitorInterval"):
+            self.project.pudata["VCSSTATUSMONITORINTERVAL"] = [vcsStatusMonitorInterval]
+        else:
+            self.project.pudata["VCSSTATUSMONITORINTERVAL"] = []
+        
+        if self.vcsGroup.isEnabled():
+            vcsSystem = self.vcsInterfaceCombo\
+                .itemData(self.vcsInterfaceCombo.currentIndex()).toString()
+            if self.vcsInterfaceDefaultCheckBox.isChecked():
+                if vcsSystem != self.project.pdata["VCS"][0]:
+                    self.project.pdata["VCS"] = [vcsSystem]
+                    self.project.pudata["VCSOVERRIDE"] = []
+                    self.project.setDirty(True)
+            else:
+                if vcsSystem != self.project.pdata["VCS"][0]:
+                    self.project.pudata["VCSOVERRIDE"] = [vcsSystem]
+                else:
+                    self.project.pudata["VCSOVERRIDE"] = []

eric ide

mercurial