You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
300 lines
14 KiB
300 lines
14 KiB
{% extends '_main.html' %}
|
|
|
|
{% block title %}Series - Bazarr{% endblock %}
|
|
|
|
{% block bcleft %}
|
|
<div class="">
|
|
<button class="btn btn-outline" id="mass_edit"
|
|
onclick="window.location.href = '{{ url_for('serieseditor') }}';">
|
|
<div><i class="fas fa-list align-top text-themecolor text-center font-20" aria-hidden="true"></i></div>
|
|
<div class="align-bottom text-themecolor small text-center">Mass Edit</div>
|
|
</button>
|
|
</div>
|
|
{% endblock bcleft %}
|
|
|
|
{% block bcright %}
|
|
|
|
{% endblock bcright %}
|
|
|
|
{% block body %}
|
|
<table id="series" class="table table-striped" style="width:100%">
|
|
<thead>
|
|
<tr>
|
|
<th>Name</th>
|
|
<th>Path Exist</th>
|
|
<th>Audio Profile</th>
|
|
<th>Subtitles Languages</th>
|
|
<th>Hearing-Impaired</th>
|
|
<th>Forced</th>
|
|
<th>Subtitles</th>
|
|
<th></th>
|
|
</tr>
|
|
</thead>
|
|
</table>
|
|
|
|
<div id="editModal" class="modal" tabindex="-1" role="dialog">
|
|
<div class="modal-dialog modal-lg" role="document">
|
|
<div class="modal-content">
|
|
<div class="modal-header">
|
|
<h5 class="modal-title"><span id="edit_series_title_span"></span></h5><br>
|
|
<button type="button" class="close" data-dismiss="modal" aria-label="Close">
|
|
<span aria-hidden="true">×</span>
|
|
</button>
|
|
</div>
|
|
<form class="form" name="edit_form" id="edit_form">
|
|
<div class="modal-body">
|
|
<div class="container-fluid">
|
|
<div class="row">
|
|
<div class="col-sm-3 text-right">
|
|
Audio Profile
|
|
</div>
|
|
<div class="form-group col-sm-8 pl-sm-0">
|
|
<span id="edit_audio_language_span"></span>
|
|
</div>
|
|
</div>
|
|
<div class="row">
|
|
<div class="col-sm-3 text-right">
|
|
Subtitles Language(s)
|
|
</div>
|
|
<div class="form-group col-sm-8 pl-sm-0">
|
|
<select class="selectpicker" id="edit_languages_select" name="languages" multiple
|
|
data-live-search="true"></select>
|
|
</div>
|
|
</div>
|
|
<div class="row">
|
|
<div class="col-sm-3 text-right">
|
|
Hearing-Impaired
|
|
</div>
|
|
<div class="form-group col-sm-1 pl-sm-0">
|
|
<label class="custom-control custom-checkbox">
|
|
<input type="checkbox" class="custom-control-input" id="hi_checkbox" name="hi">
|
|
<span class="custom-control-label" for="hi_checkbox"></span>
|
|
</label>
|
|
</div>
|
|
</div>
|
|
<div class="row">
|
|
<div class="col-sm-3 text-right">
|
|
Forced
|
|
</div>
|
|
<div class="form-group col-sm-8 pl-sm-0">
|
|
<select class="selectpicker" id="edit_forced_select" name="forced">
|
|
<option value="False">False</option>
|
|
<option value="True">True</option>
|
|
<option value="Both">Both</option>
|
|
</select>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<input type="hidden" id="edit_sonarrSeriesId" name="sonarrSeriesId" value=""/>
|
|
</div>
|
|
<div class="modal-footer">
|
|
<button type="submit" id="edit_save_button" class="btn btn-info"><span id="edit_save_button_span">Save</span></button>
|
|
<button type="button" class="btn btn-secondary" data-dismiss="modal">Cancel</button>
|
|
</div>
|
|
</form>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
{% endblock body %}
|
|
|
|
{% block tail %}
|
|
<script>
|
|
$(document).ready(function () {
|
|
getLanguages();
|
|
getEnabledLanguages();
|
|
|
|
events.on('event', function (event) {
|
|
var event_json = JSON.parse(event);
|
|
if (event_json.type === 'series' && event_json.action === 'insert') {
|
|
$.ajax({
|
|
url: "{{ url_for('api.series') }}?seriesid=" + event_json.series,
|
|
success: function (data) {
|
|
if (data.data.length) {
|
|
$('#series').DataTable().rows.add(data.data);
|
|
$('#series').DataTable().columns.adjust().draw(false);
|
|
$('[data-toggle="tooltip"]').tooltip({html: true});
|
|
}
|
|
}
|
|
})
|
|
} else if (event_json.type === 'series' && event_json.action === 'update') {
|
|
var rowId = $('#series').DataTable().row('#row_' + event_json.series);
|
|
if (rowId.length) {
|
|
$.ajax({
|
|
url: "{{ url_for('api.series') }}?seriesid=" + event_json.series,
|
|
success: function (data) {
|
|
if (data.data.length) {
|
|
$('#series').DataTable().row(rowId).data(data.data[0]).draw('page');
|
|
$('[data-toggle="tooltip"]').tooltip({html: true});
|
|
}
|
|
}
|
|
})
|
|
}
|
|
} else if (event_json.type === 'series' && event_json.action === 'delete') {
|
|
var rowId = $('#series').DataTable().row('#row_' + event_json.series);
|
|
if (rowId.length) {
|
|
$('#series').DataTable().row(rowId).remove();
|
|
$('#series').DataTable().columns.adjust().draw(false);
|
|
$('[data-toggle="tooltip"]').tooltip({html: true});
|
|
}
|
|
}
|
|
});
|
|
|
|
var table = $('#series').DataTable({
|
|
dom:
|
|
"<'row'<'col-sm-12'tr>>" +
|
|
"<'row'<'col-sm-5'i><'col-sm-7'p>>",
|
|
processing: true,
|
|
serverSide: true,
|
|
language: {
|
|
zeroRecords: 'No Series Found',
|
|
processing: "Loading Series..."
|
|
},
|
|
searching: false,
|
|
ordering: false,
|
|
lengthChange: false,
|
|
responsive: true,
|
|
pageLength: {{ settings.general.page_size }},
|
|
ajax: "{{ url_for('api.series') }}",
|
|
columns: [
|
|
{
|
|
data: null,
|
|
render: function (data) {
|
|
return '<a href="' + "{{ url_for( 'episodes', no='tempvalue' ) }}".replace("tempvalue", data.sonarrSeriesId) + '">' + data.title + '</a>';
|
|
}
|
|
},
|
|
{
|
|
data: null,
|
|
className: "dt-center",
|
|
responsivePriority: 1,
|
|
render: function (data) {
|
|
if (data.exist === false) {
|
|
return '<i class="fas fa-exclamation-triangle" data-toggle="tooltip" data-placement="right" title="This path doesn\'t seem to be valid: ' + data.mapped_path + '"></i>';
|
|
} else if (data.exist === true) {
|
|
return '<i class="fas fa-check" data-toggle="tooltip" data-placement="right" title="This path seems to be valid: ' + data.mapped_path + '"></i>';
|
|
}
|
|
}
|
|
},
|
|
{data: "audio_language.name"},
|
|
{
|
|
data: "languages",
|
|
render: function (data) {
|
|
if (data && data !== 'None') {
|
|
var languages = '';
|
|
data.forEach(appendFunc);
|
|
return languages;
|
|
} else {
|
|
return null;
|
|
}
|
|
|
|
function appendFunc(value) {
|
|
languages = languages + '<span class="badge badge-secondary" data-toggle="tooltip" data-placement="right" title="' + value.name + '">' + value.code2 + '</span> ';
|
|
}
|
|
}
|
|
},
|
|
{
|
|
data: "hearing_impaired",
|
|
className: "dt-center"
|
|
},
|
|
{
|
|
data: "forced",
|
|
className: "dt-center"
|
|
},
|
|
{
|
|
data: null,
|
|
responsivePriority: 2,
|
|
render: function (data) {
|
|
var total = data.episodeFileCount;
|
|
var completed = data.episodeFileCount - data.episodeMissingCount;
|
|
var completed_style = '';
|
|
var completed_text = '';
|
|
if (data.episodeFileCount && data.languages !== 'None') {
|
|
completed_style = ' style="width: ' + completed / total * 100 + '%;"';
|
|
completed_text = completed + '/' + total;
|
|
}
|
|
return '<div class="progress"><div class="progress-bar" role="progressbar"' + completed_style + ' aria-valuenow="' + completed + '" aria-valuemin="0" aria-valuemax="' + total + '">' + completed_text + '</div></div>'
|
|
}
|
|
},
|
|
{
|
|
data: null,
|
|
render: function (data) {
|
|
return '<a href="" class="edit_button badge badge-secondary" data-sonarrSeriesId=' + data.sonarrSeriesId + ' data-audiolanguage="' + data.audio_language.name + '" data-title="' + data.title + '" data-languages=' + JSON.stringify(data.languages) + ' data-hi="' + data.hearing_impaired + '" data-forced="' + data.forced + '"><i class="fas fa-wrench"></i></a>';
|
|
}
|
|
}
|
|
]
|
|
});
|
|
});
|
|
|
|
$('#series').on('click', '.edit_button', function (e) {
|
|
e.preventDefault();
|
|
$("#edit_series_title_span").html($(this).data('title'));
|
|
$("#edit_audio_language_span").html($(this).data('audiolanguage'));
|
|
$('#edit_sonarrSeriesId').val($(this).data('sonarrseriesid'));
|
|
|
|
|
|
$('#edit_languages_select').empty();
|
|
if ('{{settings.general.single_language}}' === 'True') {
|
|
$('#edit_languages_select').selectpicker({maxOptions: 1});
|
|
}
|
|
if ('{{settings.general.single_language}}' === 'True') {
|
|
$('#edit_languages_select').append('<option value="None">None</option>');
|
|
}
|
|
$.each(enabledLanguages, function (i, item) {
|
|
$('#edit_languages_select').append('<option value="' + item.code2 + '">' + item.name + '</option>');
|
|
});
|
|
$("#edit_languages_select").selectpicker("refresh");
|
|
var selected_languages = Array();
|
|
$.each(Array.from($(this).data('languages')), function (i, item) {
|
|
selected_languages.push(item.code2);
|
|
});
|
|
$('#edit_languages_select').selectpicker('val', selected_languages);
|
|
$('#hi_checkbox').prop('checked', ($(this).data('hi') === 'True'));
|
|
$('#edit_forced_select').val($(this).data('forced')).change();
|
|
|
|
$('#editModal')
|
|
.modal({
|
|
focus: false
|
|
});
|
|
});
|
|
|
|
$('#edit_form').on('submit', function (e) {
|
|
e.preventDefault();
|
|
var formdata = new FormData(document.getElementById("edit_form"));
|
|
|
|
$.ajax({
|
|
url: "{{ url_for('api.series') }}?seriesid=" + $('#edit_sonarrSeriesId').val(),
|
|
data: formdata,
|
|
processData: false,
|
|
contentType: false,
|
|
type: 'POST',
|
|
beforeSend: function () {
|
|
$('#edit_save_button_span').html('<div class="spinner-border spinner-border-sm" role="status"><span class="sr-only">Loading...</span></div>');
|
|
},
|
|
success: function () {
|
|
$('#editModal').modal('hide');
|
|
$('#edit_save_button_span').html('Save');
|
|
}
|
|
});
|
|
});
|
|
|
|
function getLanguages() {
|
|
$.ajax({
|
|
url: "{{ url_for('api.languages') }}?enabled=false",
|
|
success: function (data) {
|
|
availableLanguages = data;
|
|
}
|
|
});
|
|
}
|
|
|
|
function getEnabledLanguages() {
|
|
$.ajax({
|
|
url: "{{ url_for('api.languages') }}?enabled=true",
|
|
success: function (data) {
|
|
enabledLanguages = data;
|
|
}
|
|
});
|
|
}
|
|
</script>
|
|
{% endblock tail %}
|