summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--module/gui/Overview.py68
1 files changed, 59 insertions, 9 deletions
diff --git a/module/gui/Overview.py b/module/gui/Overview.py
index bbcf6f9f6..bbd175b07 100644
--- a/module/gui/Overview.py
+++ b/module/gui/Overview.py
@@ -28,6 +28,8 @@ class OverviewModel(QAbstractListModel):
Parts = 13
ETA = 14
Speed = 15
+ CurrentSize = 16
+ MaxSize = 17
def __init__(self, view, connector):
QAbstractListModel.__init__(self)
@@ -46,15 +48,30 @@ class OverviewModel(QAbstractListModel):
f += 1
return f
+ def maxSize(p):
+ s = 0
+ for c in p.children:
+ s += c.data["size"]
+ return s
+
d = self.queue._data
for p in d:
+ progress = self.queue.getProgress(p)
+ maxsize = maxSize(p)
+ speed = self.queue.getSpeed(p)
+ if speed:
+ eta = (maxsize - (maxsize * (progress/100.0)))/1024/speed
+ else:
+ eta = 0
info = {
OverviewModel.PackageName: p.data["name"],
- OverviewModel.Progress: self.queue.getProgress(p),
+ OverviewModel.Progress: progress,
OverviewModel.PartsFinished: partsFinished(p),
OverviewModel.Parts: len(p.children),
- OverviewModel.ETA: "n/a",
- OverviewModel.Speed: self.queue.getSpeed(p),
+ OverviewModel.ETA: int(eta),
+ OverviewModel.Speed: speed,
+ OverviewModel.CurrentSize: maxsize * (progress/100.0),
+ OverviewModel.MaxSize: maxsize,
}
self.packages.append(info)
@@ -68,7 +85,7 @@ class OverviewModel(QAbstractListModel):
return len(self.packages)
def data(self, index, role=Qt.DisplayRole):
- if role in [OverviewModel.PackageName, OverviewModel.Progress, OverviewModel.PartsFinished, OverviewModel.Parts, OverviewModel.ETA, OverviewModel.Speed]:
+ if role in [OverviewModel.PackageName, OverviewModel.Progress, OverviewModel.PartsFinished, OverviewModel.Parts, OverviewModel.ETA, OverviewModel.Speed, OverviewModel.CurrentSize, OverviewModel.MaxSize]:
return QVariant(self.packages[index.row()][role])
return QVariant()
@@ -97,11 +114,42 @@ class OverviewDelegate(QItemDelegate):
packagename = index.data(OverviewModel.PackageName).toString()
partsf = index.data(OverviewModel.PartsFinished).toString()
parts = index.data(OverviewModel.Parts).toString()
- eta = index.data(OverviewModel.ETA).toString()
+ eta = int(index.data(OverviewModel.ETA).toString())
speed = index.data(OverviewModel.Speed).toString() or 0
progress = int(index.data(OverviewModel.Progress).toString())
-
- statusline = QString(_("Parts: %s/%s ETA: %s Speed: %s kb/s" % (partsf, parts, eta, speed)))
+ currentSize = int(index.data(OverviewModel.CurrentSize).toString())
+ maxSize = int(index.data(OverviewModel.MaxSize).toString())
+
+ def formatEta(seconds):
+ if seconds <= 0: return ""
+ hours, seconds = divmod(seconds, 3600)
+ minutes, seconds = divmod(seconds, 60)
+ return _("ETA: %.2i:%.2i:%.2i") % (hours, minutes, seconds)
+
+ statusline = QString(_("Parts: %s/%s" % (partsf, parts)))
+ if partsf == parts:
+ speedline = _("Finished")
+ else:
+ speedline = QString(formatEta(eta) + " " + _("Speed: %s kb/s") % speed)
+
+ def formatSize(size):
+ kbytes = size/1024
+ if kbytes/1024/1024 < 1024:
+ if kbytes/1024 < 1024:
+ if kbytes <= 1:
+ size = "1 KiB"
+ else:
+ size = "%s KiB" % kbytes
+ else:
+ size = "%s MiB" % round(kbytes/1024, 2)
+ else:
+ size = "%s GiB" % round(kbytes/1024/1024, 2)
+ return size
+
+ if progress == 100:
+ sizeline = QString(_("Size: %s") % formatSize(maxSize))
+ else:
+ sizeline = QString(_("Size: %s/%s") % (formatSize(currentSize), formatSize(maxSize)))
f = painter.font()
f.setPointSize(12)
@@ -112,11 +160,13 @@ class OverviewDelegate(QItemDelegate):
painter.drawText(r.left(), r.top(), r.width(), r.height(), Qt.AlignTop | Qt.AlignLeft, packagename)
newr = painter.boundingRect(r.left(), r.top(), r.width(), r.height(), Qt.AlignTop | Qt.AlignLeft, packagename)
- f.setPointSize(11)
+ f.setPointSize(10)
f.setBold(False)
painter.setFont(f)
- painter.drawText(r.left(), newr.bottom()+4, r.width(), r.height(), Qt.AlignTop | Qt.AlignLeft, statusline)
+ painter.drawText(r.left(), newr.bottom()+5, r.width(), r.height(), Qt.AlignTop | Qt.AlignLeft, statusline)
+ painter.drawText(r.left(), newr.bottom()+5, r.width(), r.height(), Qt.AlignTop | Qt.AlignHCenter, sizeline)
+ painter.drawText(r.left(), newr.bottom()+5, r.width(), r.height(), Qt.AlignTop | Qt.AlignRight, speedline)
newr = painter.boundingRect(r.left(), newr.bottom()+2, r.width(), r.height(), Qt.AlignTop | Qt.AlignLeft, statusline)
newr.setTop(newr.bottom()+8)
newr.setBottom(newr.top()+20)