eric6/Tasks/TaskFilterConfigDialog.py

changeset 6942
2602857055c5
parent 6645
ad476851d7e0
child 7229
53054eb5b15a
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/eric6/Tasks/TaskFilterConfigDialog.py	Sun Apr 14 15:09:21 2019 +0200
@@ -0,0 +1,145 @@
+# -*- coding: utf-8 -*-
+
+# Copyright (c) 2006 - 2019 Detlev Offenbach <detlev@die-offenbachs.de>
+#
+
+"""
+Module implementing the task filter configuration dialog.
+"""
+
+from __future__ import unicode_literals
+
+from PyQt5.QtWidgets import QDialog
+
+from .Task import Task
+
+from .Ui_TaskFilterConfigDialog import Ui_TaskFilterConfigDialog
+
+
+class TaskFilterConfigDialog(QDialog, Ui_TaskFilterConfigDialog):
+    """
+    Class implementing the task filter configuration dialog.
+    """
+    def __init__(self, taskFilter, parent=None):
+        """
+        Constructor
+        
+        @param taskFilter the task filter object to be configured
+        @param parent the parent widget (QWidget)
+        """
+        super(TaskFilterConfigDialog, self).__init__(parent)
+        self.setupUi(self)
+        
+        self.typeCombo.addItem("", Task.TypeNone)
+        self.typeCombo.addItem(self.tr("Bugfix"), Task.TypeFixme)
+        self.typeCombo.addItem(self.tr("Warning"), Task.TypeWarning)
+        self.typeCombo.addItem(self.tr("ToDo"), Task.TypeTodo)
+        self.typeCombo.addItem(self.tr("Note"), Task.TypeNote)
+        
+        if taskFilter.summaryFilter is None or \
+           not taskFilter.summaryFilter.pattern():
+            self.summaryGroup.setChecked(False)
+            self.summaryEdit.clear()
+        else:
+            self.summaryGroup.setChecked(True)
+            self.summaryEdit.setText(taskFilter.summaryFilter.pattern())
+        
+        if taskFilter.filenameFilter is None or \
+           not taskFilter.filenameFilter.pattern():
+            self.filenameGroup.setChecked(False)
+            self.filenameEdit.clear()
+        else:
+            self.filenameGroup.setChecked(True)
+            self.filenameEdit.setText(taskFilter.filenameFilter.pattern())
+        
+        if taskFilter.typeFilter == Task.TypeNone:
+            self.typeGroup.setChecked(False)
+            self.typeCombo.setCurrentIndex(0)
+        else:
+            self.typeGroup.setChecked(True)
+            self.typeCombo.setCurrentIndex(
+                self.typeCombo.findData(taskFilter.typeFilter))
+        
+        if taskFilter.scopeFilter is None:
+            self.scopeGroup.setChecked(False)
+            self.globalRadioButton.setChecked(True)
+        else:
+            self.scopeGroup.setChecked(True)
+            if taskFilter.scopeFilter:
+                self.projectRadioButton.setChecked(True)
+            else:
+                self.globalRadioButton.setChecked(True)
+        
+        if taskFilter.statusFilter is None:
+            self.statusGroup.setChecked(False)
+            self.uncompletedRadioButton.setChecked(True)
+        else:
+            self.statusGroup.setChecked(True)
+            if taskFilter.statusFilter:
+                self.completedRadioButton.setChecked(True)
+            else:
+                self.uncompletedRadioButton.setChecked(True)
+        
+        if taskFilter.prioritiesFilter is None:
+            self.priorityGroup.setChecked(False)
+            self.priorityHighCheckBox.setChecked(False)
+            self.priorityNormalCheckBox.setChecked(False)
+            self.priorityLowCheckBox.setChecked(False)
+        else:
+            self.priorityGroup.setChecked(True)
+            self.priorityHighCheckBox.setChecked(
+                0 in taskFilter.prioritiesFilter)
+            self.priorityNormalCheckBox.setChecked(
+                1 in taskFilter.prioritiesFilter)
+            self.priorityLowCheckBox.setChecked(
+                2 in taskFilter.prioritiesFilter)
+        
+        msh = self.minimumSizeHint()
+        self.resize(max(self.width(), msh.width()), msh.height())
+    
+    def configureTaskFilter(self, taskFilter):
+        """
+        Public method to set the parameters of the task filter object.
+        
+        @param taskFilter the task filter object to be configured
+        """
+        if self.summaryGroup.isChecked():
+            taskFilter.setSummaryFilter(self.summaryEdit.text())
+        else:
+            taskFilter.setSummaryFilter(None)
+        
+        if self.filenameGroup.isChecked():
+            taskFilter.setFileNameFilter(self.filenameEdit.text())
+        else:
+            taskFilter.setFileNameFilter(None)
+        
+        if self.typeGroup.isChecked():
+            taskFilter.setTypeFilter(
+                self.typeCombo.itemData(self.typeCombo.currentIndex()))
+        else:
+            taskFilter.setTypeFilter(Task.TypeNone)
+        
+        if self.scopeGroup.isChecked():
+            if self.projectRadioButton.isChecked():
+                taskFilter.setScopeFilter(True)
+            else:
+                taskFilter.setScopeFilter(False)
+        else:
+            taskFilter.setScopeFilter(None)
+        
+        if self.statusGroup.isChecked():
+            if self.completedRadioButton.isChecked():
+                taskFilter.setStatusFilter(True)
+            else:
+                taskFilter.setStatusFilter(False)
+        else:
+            taskFilter.setStatusFilter(None)
+        
+        if self.priorityGroup.isChecked():
+            priorities = []
+            self.priorityHighCheckBox.isChecked() and priorities.append(0)
+            self.priorityNormalCheckBox.isChecked() and priorities.append(1)
+            self.priorityLowCheckBox.isChecked() and priorities.append(2)
+            taskFilter.setPrioritiesFilter(priorities)
+        else:
+            taskFilter.setPrioritiesFilter(None)

eric ide

mercurial