Add Magnet and Torrent File Export

This commit is contained in:
Leo Herzog
2020-06-22 21:22:03 -04:00
parent 378aa29caf
commit eb732bd68e
4 changed files with 1137 additions and 93 deletions

1155
bundle.js

File diff suppressed because it is too large Load Diff

View File

@@ -47,12 +47,27 @@
</div> </div>
<div class="form-group"> <div class="form-group">
<label class="col-form-label" for="files">Files <span id="torrentSize"></span></label> <label class="col-form-label" for="files">Files</label>
<table id="files"> <table id="files">
<tbody id="filesBody"></tbody> <tbody id="filesBody"></tbody>
</table> </table>
</div> </div>
<div>
<div id="copyMagnet">
<span class="fa-stack fa-2x">
<span class="fas fa-circle fa-stack-2x"></span>
<span class="fad fa-magnet fa-stack-1x fa-inverse" data-fa-transform="down-1"></span>
</span>
</div>
<div id="downloadTorrent">
<span class="fa-stack fa-2x">
<span class="fas fa-circle fa-stack-2x"></span>
<span class="fas fa-file-download fa-stack-1x fa-inverse"></span>
</span>
</div>
</div>
<script src="bundle.js"></script> <script src="bundle.js"></script>
</body> </body>

View File

@@ -7,8 +7,9 @@
"Buffer": "latest", "Buffer": "latest",
"browserify": "latest", "browserify": "latest",
"bytes": "latest", "bytes": "latest",
"clipboard": "latest",
"dropzone": "latest", "dropzone": "latest",
"mime-types": "^2.1.27", "mime-types": "latest",
"parse-torrent": "latest" "parse-torrent": "latest"
}, },
"devDependencies": { "devDependencies": {

View File

@@ -2,6 +2,7 @@ const parser = require('parse-torrent');
const Buffer = require('Buffer'); const Buffer = require('Buffer');
const bytes = require('bytes'); const bytes = require('bytes');
const mime = require('mime-types'); const mime = require('mime-types');
const clipboard = require('clipboard');
var name = document.getElementById('name'); var name = document.getElementById('name');
var creationDate = document.getElementById('creationDate'); var creationDate = document.getElementById('creationDate');
@@ -11,7 +12,8 @@ var hash = document.getElementById('hash');
var trackers = document.getElementById('trackers'); var trackers = document.getElementById('trackers');
var webseeds = document.getElementById('webseeds'); var webseeds = document.getElementById('webseeds');
var files = document.getElementById('filesBody'); var files = document.getElementById('filesBody');
var size = document.getElementById('torrentSize'); var copyMagnet = document.getElementById('copyMagnet');
var downloadTorrent = document.getElementById('downloadTorrent');
var parsed; var parsed;
document.addEventListener('DOMContentLoaded', start); document.addEventListener('DOMContentLoaded', start);
@@ -30,6 +32,9 @@ function start() {
event.target.files[0].arrayBuffer().then(arrayBuffer => parse(Buffer.from(arrayBuffer))); event.target.files[0].arrayBuffer().then(arrayBuffer => parse(Buffer.from(arrayBuffer)));
}); });
new clipboard('#copyMagnet'); // TODO: Alert user to success
downloadTorrent.addEventListener('click', saveTorrent);
} }
function parse(toLoad) { function parse(toLoad) {
@@ -93,27 +98,33 @@ function display() {
webseeds.innerHTML = "<em>No webseed URLs in the URL/File provided</em>"; webseeds.innerHTML = "<em>No webseed URLs in the URL/File provided</em>";
} }
size.innerHTML = "";
if (parsed.length) size.innerText = "(" + bytes.format(parsed.length, {"decimalPlaces": 1, "unitSeparator": " "}) + ")";
files.innerHTML = ""; files.innerHTML = "";
if (parsed.files && parsed.files.length) { if (parsed.files && parsed.files.length) {
for (let file of parsed.files) { for (let file of parsed.files) {
let row = document.createElement('tr'); let icon = getFontAwesomeIconForMimetype(mime.lookup(file.name));
let iconcell = document.createElement('td'); files.appendChild(createFileRow(icon, file.name, file.length));
iconcell.innerHTML = '<span class="far fa-' + getFontAwesomeIconForMimetype(mime.lookup(file.name)) + '"></span>';
row.appendChild(iconcell);
let namecell = document.createElement('td');
namecell.innerHTML = file.path;
row.appendChild(namecell);
let sizecell = document.createElement('td');
sizecell.innerHTML = bytes.format(file.length, {"unitSeparator": " "});
row.appendChild(sizecell);
files.appendChild(row);
} }
files.appendChild(createFileRow('folder-tree', '', parsed.length));
} else { } else {
files.innerHTML = "<em>Files information isn't included in the URL/File provided</em>"; files.innerHTML = "<em>Files information isn't included in the URL/File provided</em>";
} }
copyMagnet.setAttribute('data-clipboard-text', parser.toMagnetURI(parsed));
}
function createFileRow(icon, name, size) {
let row = document.createElement('tr');
let iconcell = document.createElement('td');
iconcell.innerHTML = '<span class="far fa-' + icon + '"></span>';
row.appendChild(iconcell);
let namecell = document.createElement('td');
namecell.innerHTML = name;
row.appendChild(namecell);
let totalcell = document.createElement('td');
totalcell.innerHTML = bytes.format(size, {"decimalPlaces": 1, "unitSeparator": " "});
row.appendChild(totalcell);
return row;
} }
function getFontAwesomeIconForMimetype(mimetype) { function getFontAwesomeIconForMimetype(mimetype) {
@@ -142,4 +153,20 @@ function getFontAwesomeIconForMimetype(mimetype) {
default: default:
return 'file'; return 'file';
} }
}
// https://stackoverflow.com/a/36899900/2700296
function saveTorrent() {
let data = parser.toTorrentFile(parsed);
if (data !== null && navigator.msSaveBlob)
return navigator.msSaveBlob(new Blob([data], { "type": "application/x-bittorrent" }), parsed.name + '.torrent');
let a = document.createElement('a');
a.style.display = 'none';
let url = window.URL.createObjectURL(new Blob([data], { "type": "application/x-bittorrent" }));
a.setAttribute("href", url);
a.setAttribute("download", parsed.name + '.torrent');
document.body.appendChild(a);
a.click();
window.URL.revokeObjectURL(url);
a.remove();
} }