Browse Source

Merge pull request #7997 from Piccirello/webui-content-columns

Add "Remaining" and "Availability" columns to webui Content tab
adaptive-webui-19844
sledgehammer999 7 years ago committed by GitHub
parent
commit
94b64884f8
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
  1. 3
      src/webui/btjson.cpp
  2. 4
      src/webui/www/public/properties_content.html
  3. 18
      src/webui/www/public/scripts/misc.js
  4. 4
      src/webui/www/public/scripts/progressbar.js
  5. 3
      src/webui/www/public/scripts/prop-files.js

3
src/webui/btjson.cpp

@ -182,6 +182,7 @@ static const char KEY_FILE_PROGRESS[] = "progress"; @@ -182,6 +182,7 @@ static const char KEY_FILE_PROGRESS[] = "progress";
static const char KEY_FILE_PRIORITY[] = "priority";
static const char KEY_FILE_IS_SEED[] = "is_seed";
static const char KEY_FILE_PIECE_RANGE[] = "piece_range";
static const char KEY_FILE_AVAILABILITY[] = "availability";
// TransferInfo keys
static const char KEY_TRANSFER_DLSPEED[] = "dl_info_speed";
@ -954,12 +955,14 @@ QByteArray btjson::getFilesForTorrent(const QString& hash) @@ -954,12 +955,14 @@ QByteArray btjson::getFilesForTorrent(const QString& hash)
const QVector<int> priorities = torrent->filePriorities();
const QVector<qreal> fp = torrent->filesProgress();
const QVector<qreal> fileAvailability = torrent->availableFileFractions();
const BitTorrent::TorrentInfo info = torrent->info();
for (int i = 0; i < torrent->filesCount(); ++i) {
QVariantMap fileDict;
fileDict[KEY_FILE_PROGRESS] = fp[i];
fileDict[KEY_FILE_PRIORITY] = priorities[i];
fileDict[KEY_FILE_SIZE] = torrent->fileSize(i);
fileDict[KEY_FILE_AVAILABILITY] = fileAvailability[i];
QString fileName = torrent->filePath(i);
if (fileName.endsWith(QB_EXT, Qt::CaseInsensitive))

4
src/webui/www/public/properties_content.html

@ -105,7 +105,9 @@ @@ -105,7 +105,9 @@
<th>QBT_TR(Name)QBT_TR[CONTEXT=TorrentContentModel]</th>
<th style="width: 150px;">QBT_TR(Size)QBT_TR[CONTEXT=TorrentContentModel]</th>
<th style="width: 90px;">QBT_TR(Progress)QBT_TR[CONTEXT=TorrentContentModel]</th>
<th style="width: 150px; border-right: 0">QBT_TR(Download Priority)QBT_TR[CONTEXT=TorrentContentModel]</th>
<th style="width: 150px;">QBT_TR(Download Priority)QBT_TR[CONTEXT=TorrentContentModel]</th>
<th style="width: 150px;">QBT_TR(Remaining)QBT_TR[CONTEXT=TorrentContentModel]</th>
<th style="width: 150px; border-right: 0">QBT_TR(Availability)QBT_TR[CONTEXT=TorrentContentModel]</th>
</tr>
</thead>
<tbody id="filesTable"></tbody>

18
src/webui/www/public/scripts/misc.js

@ -30,9 +30,12 @@ function friendlyUnit(value, isSpeed) { @@ -30,9 +30,12 @@ function friendlyUnit(value, isSpeed) {
var ret;
if (i === 0)
ret = value + " " + units[i];
else
ret = (Math.floor(10 * value) / 10).toFixed(friendlyUnitPrecision(i)) //Don't round up
+ " " + units[i];
else {
var precision = friendlyUnitPrecision(i);
var offset = Math.pow(10, precision);
// Don't round up
ret = (Math.floor(offset * value) / offset).toFixed(precision) + " " + units[i];
}
if (isSpeed)
ret += "QBT_TR(/s)QBT_TR[CONTEXT=misc]";
@ -64,6 +67,15 @@ function friendlyDuration(seconds) { @@ -64,6 +67,15 @@ function friendlyDuration(seconds) {
return "∞";
}
function friendlyPercentage(value) {
var percentage = (value * 100).round(1);
if (isNaN(percentage) || (percentage < 0))
percentage = 0;
if (percentage > 100)
percentage = 100;
return percentage.toFixed(1) + "%";
}
/*
* From: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Date/toISOString
*/

4
src/webui/www/public/scripts/progressbar.js

@ -78,8 +78,8 @@ function ProgressBar_setValue(value) { @@ -78,8 +78,8 @@ function ProgressBar_setValue(value) {
this.vals.value = value;
this.vals.dark.empty();
this.vals.light.empty();
this.vals.dark.appendText(value + '%');
this.vals.light.appendText(value + '%');
this.vals.dark.appendText(value.round(1).toFixed(1) + '%');
this.vals.light.appendText(value.round(1).toFixed(1) + '%');
var r = parseInt(this.vals.width * (value / 100));
this.vals.dark.setStyle('clip', 'rect(0,' + r + 'px,' + this.vals.height + 'px,0)');
this.vals.light.setStyle('clip', 'rect(0,' + this.vals.width + 'px,' + this.vals.height + 'px,' + r + 'px)');

3
src/webui/www/public/scripts/prop-files.js

@ -317,6 +317,9 @@ var loadTorrentFilesData = function() { @@ -317,6 +317,9 @@ var loadTorrentFilesData = function() {
if (row[3] == 100.0 && file.progress < 1.0)
row[3] = 99.9;
row[4] = file.priority;
row[5] = friendlyUnit(file.size * (1.0 - file.progress));
row[6] = friendlyPercentage(file.availability);
fTable.insertRow(i, row);
i++;
}.bind(this));

Loading…
Cancel
Save