mirror of
https://github.com/Tautulli/Tautulli.git
synced 2024-11-24 06:20:27 -08:00
c13b1a67f2
* Fixes #1532
255 lines
9.8 KiB
JavaScript
255 lines
9.8 KiB
JavaScript
var date_format = 'YYYY-MM-DD';
|
|
var time_format = 'hh:mm a';
|
|
|
|
$.ajax({
|
|
url: 'get_date_formats',
|
|
type: 'GET',
|
|
success: function (data) {
|
|
date_format = data.date_format;
|
|
time_format = data.time_format;
|
|
}
|
|
});
|
|
|
|
export_table_options = {
|
|
"destroy": true,
|
|
"language": {
|
|
"search": "Search: ",
|
|
"lengthMenu": "Show _MENU_ entries per page",
|
|
"info": "Showing _START_ to _END_ of _TOTAL_ export items",
|
|
"infoEmpty": "Showing 0 to 0 of 0 entries",
|
|
"infoFiltered": "<span class='hidden-md hidden-sm hidden-xs'>(filtered from _MAX_ total entries)</span>",
|
|
"emptyTable": "No data in table",
|
|
"loadingRecords": '<i class="fa fa-refresh fa-spin"></i> Loading items...</div>'
|
|
},
|
|
"pagingType": "full_numbers",
|
|
"stateSave": true,
|
|
"stateSaveParams": function (settings, data) {
|
|
data.search.search = "";
|
|
data.start = 0;
|
|
},
|
|
"stateDuration": 0,
|
|
"processing": false,
|
|
"serverSide": true,
|
|
"pageLength": 25,
|
|
"order": [0, 'desc'],
|
|
"autoWidth": false,
|
|
"scrollX": true,
|
|
"columnDefs": [
|
|
{
|
|
"targets": [0],
|
|
"data": "timestamp",
|
|
"createdCell": function (td, cellData, rowData, row, col) {
|
|
if (cellData !== '') {
|
|
$(td).html(moment(cellData, "X").format(date_format + ' ' + time_format));
|
|
}
|
|
},
|
|
"width": "8%",
|
|
"className": "no-wrap",
|
|
"searchable": false
|
|
},
|
|
{
|
|
"targets": [1],
|
|
"data": "media_type_title",
|
|
"createdCell": function (td, cellData, rowData, row, col) {
|
|
if (cellData !== '') {
|
|
$(td).html(cellData);
|
|
}
|
|
},
|
|
"width": "7%",
|
|
"className": "no-wrap"
|
|
},
|
|
{
|
|
"targets": [2],
|
|
"data": "rating_key",
|
|
"createdCell": function (td, cellData, rowData, row, col) {
|
|
if (cellData !== null) {
|
|
$(td).html('<a href="' + page('info', rowData['rating_key']) + '">' + cellData + '</a>');
|
|
}
|
|
},
|
|
"width": "6%",
|
|
"className": "no-wrap"
|
|
},
|
|
{
|
|
"targets": [3],
|
|
"data": "title",
|
|
"createdCell": function (td, cellData, rowData, row, col) {
|
|
if (cellData !== '') {
|
|
var tooltip;
|
|
var filename;
|
|
if (!rowData['individual_files']) {
|
|
tooltip = '<span data-toggle="tooltip" title="Single File"><i class="fa fa-file-alt fa-fw"></i></span>';
|
|
filename = cellData + '.' + rowData['file_format']
|
|
} else {
|
|
tooltip = '<span data-toggle="tooltip" title="Multiple Files"><i class="fa fa-folder fa-fw"></i></span>';
|
|
filename = cellData
|
|
}
|
|
|
|
if (rowData['complete'] === 1 && rowData['exists'] && !rowData['individual_files']) {
|
|
$(td).html('<a href="view_export?export_id=' + rowData['export_id'] + '" target="_blank">' + tooltip + ' ' + filename + '</a>');
|
|
} else {
|
|
$(td).html(tooltip + ' ' + filename);
|
|
}
|
|
}
|
|
},
|
|
"width": "40%",
|
|
"className": "no-wrap"
|
|
},
|
|
{
|
|
"targets": [4],
|
|
"data": "file_format",
|
|
"createdCell": function (td, cellData, rowData, row, col) {
|
|
if (cellData !== '') {
|
|
var images = '';
|
|
if (rowData['thumb_level'] || rowData['art_level']) {
|
|
images = ' + images';
|
|
}
|
|
$(td).html(cellData + images);
|
|
}
|
|
},
|
|
"width": "7%",
|
|
"className": "no-wrap"
|
|
},
|
|
{
|
|
"targets": [5],
|
|
"data": "metadata_level",
|
|
"createdCell": function (td, cellData, rowData, row, col) {
|
|
if (cellData !== null) {
|
|
$(td).html(cellData);
|
|
}
|
|
},
|
|
"width": "6%",
|
|
"className": "no-wrap"
|
|
},
|
|
{
|
|
"targets": [6],
|
|
"data": "media_info_level",
|
|
"createdCell": function (td, cellData, rowData, row, col) {
|
|
if (cellData !== null) {
|
|
$(td).html(cellData);
|
|
}
|
|
},
|
|
"width": "6%",
|
|
"className": "no-wrap"
|
|
},
|
|
{
|
|
"targets": [7],
|
|
"data": "custom_fields",
|
|
"createdCell": function (td, cellData, rowData, row, col) {
|
|
if (cellData !== '') {
|
|
$(td).html(cellData.replace(/,/g, ', '));
|
|
}
|
|
},
|
|
"width": "6%",
|
|
"className": "datatable-wrap"
|
|
},
|
|
{
|
|
"targets": [8],
|
|
"data": "file_size",
|
|
"createdCell": function (td, cellData, rowData, row, col) {
|
|
if (cellData !== '' && cellData !== null) {
|
|
$(td).html(humanFileSize(cellData));
|
|
}
|
|
},
|
|
"width": "6%",
|
|
"className": "no-wrap",
|
|
"searchable": false
|
|
},
|
|
{
|
|
"targets": [9],
|
|
"data": "complete",
|
|
"createdCell": function (td, cellData, rowData, row, col) {
|
|
if (cellData === 1 && rowData['exists']) {
|
|
var tooltip_title = '';
|
|
var icon = '';
|
|
if (rowData['thumb_level'] || rowData['art_level'] || rowData['individual_files']) {
|
|
tooltip_title = 'Zip Archive';
|
|
icon = 'fa-file-archive';
|
|
} else {
|
|
tooltip_title = rowData['file_format'].toUpperCase() + ' File';
|
|
icon = 'fa-file-download';
|
|
}
|
|
var icon = (rowData['thumb_level'] || rowData['art_level'] || rowData['individual_files']) ? 'fa-file-archive' : 'fa-file-download';
|
|
$(td).html('<button class="btn btn-xs btn-success pull-left" data-id="' + rowData['export_id'] + '"><span data-toggle="tooltip" data-placement="left" title="' + tooltip_title + '"><i class="fa ' + icon + ' fa-fw"></i> Download</span></button>');
|
|
} else if (cellData === 0) {
|
|
var percent = Math.min(getPercent(rowData['exported_items'], rowData['total_items']), 99)
|
|
$(td).html('<span class="btn btn-xs btn-dark pull-left export-processing" data-id="' + rowData['export_id'] + '" disabled><i class="fa fa-spinner fa-spin fa-fw"></i> ' + percent + '%</span>');
|
|
} else if (cellData === -1) {
|
|
$(td).html('<span class="btn btn-xs btn-dark pull-left" data-id="' + rowData['export_id'] + '" disabled><i class="fa fa-exclamation-circle fa-fw"></i> Failed</span>');
|
|
} else {
|
|
$(td).html('<span class="btn btn-xs btn-dark pull-left" data-id="' + rowData['export_id'] + '" disabled><i class="fa fa-question-circle fa-fw"></i> Not Found</span>');
|
|
}
|
|
},
|
|
"width": "7%",
|
|
"className": "export_download",
|
|
"searchable": false
|
|
},
|
|
{
|
|
"targets": [10],
|
|
"data": null,
|
|
"createdCell": function (td, cellData, rowData, row, col) {
|
|
if (rowData['complete'] !== 0) {
|
|
$(td).html('<button class="btn btn-xs btn-danger pull-left" data-id="' + rowData['export_id'] + '"><i class="fa fa-trash-o fa-fw"></i> Delete</button>');
|
|
} else {
|
|
$(td).html('<span class="btn btn-xs btn-danger pull-left" data-id="' + rowData['export_id'] + '" disabled><i class="fa fa-trash-o fa-fw"></i> Delete</span>');
|
|
}
|
|
},
|
|
"width": "7%",
|
|
"className": "export_delete",
|
|
"searchable": false
|
|
}
|
|
],
|
|
"drawCallback": function (settings) {
|
|
// Jump to top of page
|
|
//$('html,body').scrollTop(0);
|
|
$('#ajaxMsg').fadeOut();
|
|
|
|
// Create the tooltips.
|
|
$('body').tooltip({
|
|
selector: '[data-toggle="tooltip"]',
|
|
container: 'body'
|
|
});
|
|
|
|
if (export_processing_timer) {
|
|
clearTimeout(export_processing_timer);
|
|
}
|
|
if ($('.export-processing').length) {
|
|
export_processing_timer = setTimeout(redrawExportTable.bind(null, false), 2000);
|
|
}
|
|
},
|
|
"preDrawCallback": function(settings) {
|
|
if (!export_processing_timer) {
|
|
var msg = "<i class='fa fa-refresh fa-spin'></i> Fetching rows...";
|
|
showMsg(msg, false, false, 0)
|
|
}
|
|
},
|
|
"rowCallback": function (row, rowData, rowIndex) {
|
|
if (rowData['complete'] === 0) {
|
|
$(row).addClass('current-activity-row');
|
|
}
|
|
}
|
|
};
|
|
|
|
$('.export_table').on('click', '> tbody > tr > td.export_download > button', function (e) {
|
|
var tr = $(this).closest('tr');
|
|
var row = export_table.row(tr);
|
|
var rowData = row.data();
|
|
|
|
e.preventDefault();
|
|
window.location.href = 'download_export?export_id=' + rowData['export_id'];
|
|
});
|
|
|
|
$('.export_table').on('click', '> tbody > tr > td.export_delete > button', function (e) {
|
|
var tr = $(this).closest('tr');
|
|
var row = export_table.row(tr);
|
|
var rowData = row.data();
|
|
|
|
var msg = 'Are you sure you want to delete the following export?<br /><br /><strong>' + rowData['title'] + '</strong>';
|
|
var url = 'delete_export?export_id=' + rowData['export_id'];
|
|
confirmAjaxCall(url, msg, null, null, redrawExportTable);
|
|
});
|
|
|
|
function redrawExportTable(paging) {
|
|
export_table.draw(paging);
|
|
}
|
|
|
|
var export_processing_timer; |