Add ProgressIndicator to ImportTask
This commit is contained in:
parent
ce46c8daca
commit
b9b359331b
@ -1,10 +1,10 @@
|
|||||||
from fime.config import Config
|
|
||||||
|
|
||||||
try:
|
try:
|
||||||
from PySide6 import QtGui, QtWidgets
|
from PySide6 import QtCore, QtGui, QtWidgets
|
||||||
except ImportError:
|
except ImportError:
|
||||||
from PySide2 import QtGui, QtWidgets
|
from PySide2 import QtCore, QtGui, QtWidgets
|
||||||
|
|
||||||
|
from fime.config import Config
|
||||||
|
from fime.progressindicator import ProgressIndicator
|
||||||
from fime.task_completer import TaskCompleter
|
from fime.task_completer import TaskCompleter
|
||||||
from fime.util import get_icon
|
from fime.util import get_icon
|
||||||
|
|
||||||
@ -14,11 +14,18 @@ class ImportTask(QtWidgets.QDialog):
|
|||||||
super().__init__(parent, *args, **kwargs)
|
super().__init__(parent, *args, **kwargs)
|
||||||
self.setWindowTitle("New Tasks")
|
self.setWindowTitle("New Tasks")
|
||||||
|
|
||||||
self.line_edit = QtWidgets.QLineEdit()
|
self.line_edit = QtWidgets.QLineEdit(self)
|
||||||
completer = TaskCompleter(config)
|
completer = TaskCompleter(config)
|
||||||
self.line_edit.setCompleter(completer)
|
self.line_edit.setCompleter(completer)
|
||||||
self.line_edit.textChanged.connect(completer.update_picker)
|
self.line_edit.textChanged.connect(completer.update_picker)
|
||||||
|
|
||||||
|
self.indicator = ProgressIndicator(self)
|
||||||
|
self.indicator.setAnimationDelay(70)
|
||||||
|
self.indicator.setDisplayedWhenStopped(False)
|
||||||
|
self.indicator.startAnimation()
|
||||||
|
completer.running.connect(self.spin)
|
||||||
|
completer.stopped.connect(self.no_spin)
|
||||||
|
|
||||||
ok_button = QtWidgets.QPushButton()
|
ok_button = QtWidgets.QPushButton()
|
||||||
ok_button.setText("OK")
|
ok_button.setText("OK")
|
||||||
ok_button.setIcon(get_icon("dialog-ok"))
|
ok_button.setIcon(get_icon("dialog-ok"))
|
||||||
@ -31,17 +38,40 @@ class ImportTask(QtWidgets.QDialog):
|
|||||||
cancel_button.pressed.connect(self.reject)
|
cancel_button.pressed.connect(self.reject)
|
||||||
cancel_button.setAutoDefault(False)
|
cancel_button.setAutoDefault(False)
|
||||||
|
|
||||||
|
alayout = QtWidgets.QStackedLayout()
|
||||||
|
alayout.setStackingMode(QtWidgets.QStackedLayout.StackAll)
|
||||||
|
alayout.addWidget(self.line_edit)
|
||||||
|
size = self.line_edit.height()
|
||||||
|
self.indicator.setMaximumSize(QtCore.QSize(size * 0.75, size * 0.75))
|
||||||
|
aalayout = QtWidgets.QVBoxLayout()
|
||||||
|
aalayout.addWidget(self.indicator, alignment=QtCore.Qt.AlignRight | QtCore.Qt.AlignVCenter)
|
||||||
|
marg = aalayout.contentsMargins()
|
||||||
|
marg.setRight(size * 0.15)
|
||||||
|
aalayout.setContentsMargins(marg)
|
||||||
|
aawidget = QtWidgets.QWidget()
|
||||||
|
aawidget.setLayout(aalayout)
|
||||||
|
alayout.addWidget(aawidget)
|
||||||
|
alayout.setCurrentWidget(aawidget)
|
||||||
|
|
||||||
blayout = QtWidgets.QHBoxLayout()
|
blayout = QtWidgets.QHBoxLayout()
|
||||||
blayout.addSpacing(300)
|
blayout.addSpacing(300)
|
||||||
blayout.addWidget(cancel_button)
|
blayout.addWidget(cancel_button)
|
||||||
blayout.addWidget(ok_button)
|
blayout.addWidget(ok_button)
|
||||||
|
|
||||||
layout = QtWidgets.QVBoxLayout()
|
layout = QtWidgets.QVBoxLayout()
|
||||||
layout.addWidget(self.line_edit)
|
layout.addLayout(alayout)
|
||||||
layout.addLayout(blayout)
|
layout.addLayout(blayout)
|
||||||
self.setLayout(layout)
|
self.setLayout(layout)
|
||||||
self.resize(500, 0)
|
self.resize(500, 0)
|
||||||
|
|
||||||
|
@QtCore.Slot()
|
||||||
|
def spin(self):
|
||||||
|
self.indicator.startAnimation()
|
||||||
|
|
||||||
|
@QtCore.Slot()
|
||||||
|
def no_spin(self):
|
||||||
|
self.indicator.stopAnimation()
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def task_text(self):
|
def task_text(self):
|
||||||
return self.line_edit.text()
|
return self.line_edit.text()
|
||||||
|
@ -8,7 +8,7 @@ except ImportError:
|
|||||||
from PySide2 import QtCore, QtGui, QtWidgets
|
from PySide2 import QtCore, QtGui, QtWidgets
|
||||||
|
|
||||||
|
|
||||||
class QProgressIndicator(QtWidgets.QWidget):
|
class ProgressIndicator(QtWidgets.QWidget):
|
||||||
m_angle = None
|
m_angle = None
|
||||||
m_timerId = None
|
m_timerId = None
|
||||||
m_delay = None
|
m_delay = None
|
||||||
@ -30,7 +30,7 @@ class QProgressIndicator(QtWidgets.QWidget):
|
|||||||
self.m_color = QtCore.Qt.black
|
self.m_color = QtCore.Qt.black
|
||||||
|
|
||||||
# Set size and focus policy
|
# Set size and focus policy
|
||||||
self.setSizePolicy(QtWidgets.QSizePolicy.Fixed, QtWidgets.QSizePolicy.Fixed)
|
self.setSizePolicy(QtWidgets.QSizePolicy.MinimumExpanding, QtWidgets.QSizePolicy.MinimumExpanding)
|
||||||
self.setFocusPolicy(QtCore.Qt.NoFocus)
|
self.setFocusPolicy(QtCore.Qt.NoFocus)
|
||||||
|
|
||||||
# Show the widget
|
# Show the widget
|
||||||
@ -43,7 +43,7 @@ class QProgressIndicator(QtWidgets.QWidget):
|
|||||||
return (self.m_timerId != -1)
|
return (self.m_timerId != -1)
|
||||||
|
|
||||||
def isDisplayedWhenStopped(self):
|
def isDisplayedWhenStopped(self):
|
||||||
return self.displayedWhenStopped
|
return self.m_displayedWhenStopped
|
||||||
|
|
||||||
def getColor(self):
|
def getColor(self):
|
||||||
return self.color
|
return self.color
|
||||||
@ -74,7 +74,7 @@ class QProgressIndicator(QtWidgets.QWidget):
|
|||||||
self.m_timerId = self.startTimer(self.m_delay)
|
self.m_timerId = self.startTimer(self.m_delay)
|
||||||
|
|
||||||
def setDisplayedWhenStopped(self, state):
|
def setDisplayedWhenStopped(self, state):
|
||||||
self.displayedWhenStopped = state
|
self.m_displayedWhenStopped = state
|
||||||
self.update()
|
self.update()
|
||||||
|
|
||||||
def setColor(self, color):
|
def setColor(self, color):
|
||||||
|
@ -1,6 +1,8 @@
|
|||||||
import os
|
import os
|
||||||
import sys
|
import sys
|
||||||
|
import threading
|
||||||
import traceback
|
import traceback
|
||||||
|
from enum import Enum, auto
|
||||||
from functools import reduce
|
from functools import reduce
|
||||||
from queue import Queue, Empty
|
from queue import Queue, Empty
|
||||||
from urllib.parse import urlparse, parse_qs
|
from urllib.parse import urlparse, parse_qs
|
||||||
@ -15,6 +17,13 @@ from fime.config import Config
|
|||||||
|
|
||||||
|
|
||||||
class TaskCompleter(QtWidgets.QCompleter):
|
class TaskCompleter(QtWidgets.QCompleter):
|
||||||
|
class RifState(Enum):
|
||||||
|
RUNNING = auto()
|
||||||
|
STOPPED = auto()
|
||||||
|
|
||||||
|
running = QtCore.Signal()
|
||||||
|
stopped = QtCore.Signal()
|
||||||
|
|
||||||
def __init__(self, config: Config, parent=None, *args, **kwargs):
|
def __init__(self, config: Config, parent=None, *args, **kwargs):
|
||||||
super().__init__([], parent, *args, **kwargs)
|
super().__init__([], parent, *args, **kwargs)
|
||||||
self.setFilterMode(QtCore.Qt.MatchFlag.MatchContains)
|
self.setFilterMode(QtCore.Qt.MatchFlag.MatchContains)
|
||||||
@ -29,11 +38,22 @@ class TaskCompleter(QtWidgets.QCompleter):
|
|||||||
self.escalate = False
|
self.escalate = False
|
||||||
self.update_timer = QtCore.QTimer(self)
|
self.update_timer = QtCore.QTimer(self)
|
||||||
self.update_timer.timeout.connect(self.process_response)
|
self.update_timer.timeout.connect(self.process_response)
|
||||||
self.update_timer.setInterval(250)
|
self.update_timer.setInterval(200)
|
||||||
self.queue = Queue()
|
self.queue = Queue()
|
||||||
|
# Request In Flight
|
||||||
|
self.rif_counter = 0
|
||||||
|
self.rif_counter_lock = threading.Lock()
|
||||||
|
self.last_rif_state = TaskCompleter.RifState.STOPPED
|
||||||
|
|
||||||
@QtCore.Slot()
|
@QtCore.Slot()
|
||||||
def process_response(self):
|
def process_response(self):
|
||||||
|
with self.rif_counter_lock:
|
||||||
|
if self.last_rif_state is TaskCompleter.RifState.STOPPED and self.rif_counter != 0:
|
||||||
|
self.last_rif_state = TaskCompleter.RifState.RUNNING
|
||||||
|
self.running.emit()
|
||||||
|
if self.last_rif_state is TaskCompleter.RifState.RUNNING and self.rif_counter == 0:
|
||||||
|
self.last_rif_state = TaskCompleter.RifState.STOPPED
|
||||||
|
self.stopped.emit()
|
||||||
try:
|
try:
|
||||||
while not self.queue.empty():
|
while not self.queue.empty():
|
||||||
result_dict = self.queue.get_nowait()
|
result_dict = self.queue.get_nowait()
|
||||||
@ -68,9 +88,13 @@ class TaskCompleter(QtWidgets.QCompleter):
|
|||||||
"Accept": "application/json",
|
"Accept": "application/json",
|
||||||
},
|
},
|
||||||
)
|
)
|
||||||
|
with self.rif_counter_lock:
|
||||||
|
self.rif_counter += 1
|
||||||
future.add_done_callback(self.picker_response_callback)
|
future.add_done_callback(self.picker_response_callback)
|
||||||
|
|
||||||
def picker_response_callback(self, future):
|
def picker_response_callback(self, future):
|
||||||
|
with self.rif_counter_lock:
|
||||||
|
self.rif_counter -= 1
|
||||||
try:
|
try:
|
||||||
result = future.result()
|
result = future.result()
|
||||||
parsed = urlparse(result.request.url)
|
parsed = urlparse(result.request.url)
|
||||||
@ -106,9 +130,13 @@ class TaskCompleter(QtWidgets.QCompleter):
|
|||||||
"Accept": "application/json",
|
"Accept": "application/json",
|
||||||
},
|
},
|
||||||
)
|
)
|
||||||
|
with self.rif_counter_lock:
|
||||||
|
self.rif_counter += 1
|
||||||
future.add_done_callback(self.search_response_callback)
|
future.add_done_callback(self.search_response_callback)
|
||||||
|
|
||||||
def search_response_callback(self, future):
|
def search_response_callback(self, future):
|
||||||
|
with self.rif_counter_lock:
|
||||||
|
self.rif_counter -= 1
|
||||||
try:
|
try:
|
||||||
result = future.result()
|
result = future.result()
|
||||||
json_result = result.json()
|
json_result = result.json()
|
||||||
|
@ -4,7 +4,7 @@ from PySide2.QtQuickWidgets import QQuickWidget
|
|||||||
from PySide2.QtWidgets import QLabel
|
from PySide2.QtWidgets import QLabel
|
||||||
|
|
||||||
from fime.ok_icon import OkIcon
|
from fime.ok_icon import OkIcon
|
||||||
from fime.progressindicator import QProgressIndicator
|
from fime.progressindicator import ProgressIndicator
|
||||||
from fime.spinner import Spinner
|
from fime.spinner import Spinner
|
||||||
|
|
||||||
try:
|
try:
|
||||||
@ -52,7 +52,7 @@ class Worklog(QtWidgets.QDialog):
|
|||||||
self.tableWidget.setItem(row, 0, item0)
|
self.tableWidget.setItem(row, 0, item0)
|
||||||
size = self.tableWidget.rowHeight(row)
|
size = self.tableWidget.rowHeight(row)
|
||||||
if row == 1:
|
if row == 1:
|
||||||
qpi = QProgressIndicator(self)
|
qpi = ProgressIndicator(self)
|
||||||
qpi.setMaximumSize(QtCore.QSize(size * 0.75, size * 0.75))
|
qpi.setMaximumSize(QtCore.QSize(size * 0.75, size * 0.75))
|
||||||
qpi.setAnimationDelay(70)
|
qpi.setAnimationDelay(70)
|
||||||
qpi.startAnimation()
|
qpi.startAnimation()
|
||||||
|
Loading…
Reference in New Issue
Block a user