anki-word-query/src/fastwq/progress.py

130 lines
4.0 KiB
Python
Raw Normal View History

2018-07-02 01:25:53 +08:00
#-*- coding:utf-8 -*-
#
2018-07-07 17:48:15 +08:00
# Copyright © 20162017 sthoo <sth201807@gmail.com>
2018-07-02 01:25:53 +08:00
#
# Support: Report an issue at https://github.com/sth2018/FastWordQuery/issues
#
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# any later version; http://www.gnu.org/copyleft/gpl.html.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
2018-07-01 10:55:30 +08:00
import time
from collections import defaultdict
2018-07-13 11:19:29 +08:00
from PyQt4 import QtCore, QtGui
2018-07-01 10:55:30 +08:00
from .lang import _
2018-07-13 11:31:12 +08:00
__all__ = ['INFO_TEMPLATE', 'ProgressWindow']
2018-07-13 11:19:29 +08:00
INFO_TEMPLATE = u''.join([
_('QUERIED') + u'<br>' + 45 * u'-' + u'<br>',
_('SUCCESS') + u' {} ' + _('WORDS') + u'<br>',
_('SKIPED') + u' {} ' + _('WORDS') + u'<br>',
_('UPDATE') + u' {} ' + _('FIELDS') + u'<br>',
_('FAILURE') + u' {} ' + _('WORDS') + u'<br>'
])
2018-07-02 01:16:20 +08:00
class ProgressWindow(object):
"""
Query progress window
"""
2018-07-01 10:55:30 +08:00
def __init__(self, mw):
self.mw = mw
2018-07-13 11:19:29 +08:00
self.app = QtGui.QApplication.instance()
2018-07-01 10:55:30 +08:00
self._win = None
self._msg_count = defaultdict(int)
def update_labels(self, data):
if self.abort():
return
2018-07-01 18:12:31 +08:00
2018-07-01 10:55:30 +08:00
if data.type == 'count':
self._msg_count.update(data)
else:
2018-07-01 18:12:31 +08:00
return
2018-07-01 10:55:30 +08:00
2018-07-13 11:19:29 +08:00
words_number, fields_number, fails_number, skips_number = (
self._msg_count.get('words_number', 0),
self._msg_count.get('fields_number', 0),
self._msg_count.get('fails_number', 0),
self._msg_count.get('skips_number', 0)
2018-07-01 18:12:31 +08:00
)
2018-07-13 11:19:29 +08:00
number_info = INFO_TEMPLATE.format(
words_number,
skips_number,
fields_number,
fails_number
)
self._update(label=number_info, value=words_number+skips_number+fails_number)
2018-07-01 10:55:30 +08:00
self._win.adjustSize()
def update_title(self, title):
2018-07-02 01:16:20 +08:00
if self.abort():
return
2018-07-01 10:55:30 +08:00
self._win.setWindowTitle(title)
2018-07-02 01:16:20 +08:00
def start(self, max=0, min=0, label=None, parent=None):
2018-07-01 10:55:30 +08:00
self._msg_count.clear()
# setup window
label = label or _("Processing...")
2018-07-02 01:16:20 +08:00
parent = parent or self.app.activeWindow() or self.mw
2018-07-13 11:19:29 +08:00
self._win = QtGui.QProgressDialog(label, '', min, max, parent)
self._win.setWindowModality(QtCore.Qt.ApplicationModal)
2018-07-02 01:16:20 +08:00
self._win.setCancelButton(None)
self._win.canceled.connect(self.finish)
self._win.setWindowTitle("Querying...")
2018-07-01 10:55:30 +08:00
# we need to manually manage minimum time to show, as qt gets confused
# by the db handler
2018-07-02 01:16:20 +08:00
# self._win.setMinimumDuration(100000)
2018-07-01 10:55:30 +08:00
self._counter = min
self._min = min
self._max = max
self._firstTime = time.time()
self._lastUpdate = time.time()
self._disabled = False
2018-07-02 01:16:20 +08:00
self._win.show()
self.app.processEvents()
2018-07-01 10:55:30 +08:00
2018-07-02 01:16:20 +08:00
def abort(self):
# self.aborted = True
return self._win.wasCanceled()
def finish(self):
self._win.hide()
self._unsetBusy()
self._win.destroy()
def _update(self, label=None, value=None, process=True, maybeShow=True):
2018-07-01 10:55:30 +08:00
elapsed = time.time() - self._lastUpdate
if label:
self._win.setLabelText(label)
2018-07-02 01:16:20 +08:00
if self._max:
2018-07-01 10:55:30 +08:00
self._counter = value or (self._counter + 1)
self._win.setValue(self._counter)
if process and elapsed >= 0.2:
2018-07-13 11:19:29 +08:00
self.app.processEvents(QtCore.QEventLoop.ExcludeUserInputEvents)
2018-07-01 10:55:30 +08:00
self._lastUpdate = time.time()
def _setBusy(self):
self._disabled = True
2018-07-13 11:19:29 +08:00
self.mw.app.setOverrideCursor(QtGui.QCursor(QtCore.Qt.WaitCursor))
2018-07-01 10:55:30 +08:00
def _unsetBusy(self):
self._disabled = False
self.app.restoreOverrideCursor()