mirror of
https://github.com/morpheus65535/bazarr.git
synced 2025-01-21 14:17:56 +08:00
255 lines
No EOL
8.6 KiB
Smarty
255 lines
No EOL
8.6 KiB
Smarty
<html>
|
|
<head>
|
|
<!DOCTYPE html>
|
|
<script src="{{base_url}}static/jquery/jquery-latest.min.js"></script>
|
|
<script src="{{base_url}}static/semantic/semantic.min.js"></script>
|
|
<script src="{{base_url}}static/jquery/tablesort.js"></script>
|
|
<link rel="stylesheet" href="{{base_url}}static/semantic/semantic.min.css">
|
|
|
|
<link rel="apple-touch-icon" sizes="120x120" href="{{base_url}}static/apple-touch-icon.png">
|
|
<link rel="icon" type="image/png" sizes="32x32" href="{{base_url}}static/favicon-32x32.png">
|
|
<link rel="icon" type="image/png" sizes="16x16" href="{{base_url}}static/favicon-16x16.png">
|
|
<link rel="manifest" href="{{base_url}}static/manifest.json">
|
|
<link rel="mask-icon" href="{{base_url}}static/safari-pinned-tab.svg" color="#5bbad5">
|
|
<link rel="shortcut icon" href="{{base_url}}static/favicon.ico">
|
|
<meta name="msapplication-config" content="{{base_url}}static/browserconfig.xml">
|
|
<meta name="theme-color" content="#ffffff">
|
|
|
|
<title>{{details[0]}} - Bazarr</title>
|
|
<style>
|
|
body {
|
|
background-color: #1b1c1d;
|
|
background-image: url("{{base_url}}image_proxy{{details[3]}}");
|
|
background-repeat: no-repeat;
|
|
background-attachment: fixed;
|
|
background-size: cover;
|
|
background-position:center center;
|
|
}
|
|
#divmenu {
|
|
background-color: #272727;
|
|
opacity: 0.9;
|
|
padding-top: 2em;
|
|
padding-bottom: 1em;
|
|
padding-left: 1em;
|
|
padding-right: 128px;
|
|
}
|
|
#divdetails {
|
|
background-color: #000000;
|
|
opacity: 0.9;
|
|
color: #ffffff;
|
|
margin-top: 6em;
|
|
margin-bottom: 3em;
|
|
padding: 2em;
|
|
border-radius: 1px;
|
|
box-shadow: 0px 0px 5px 5px #000000;
|
|
min-height: calc(250px + 4em);
|
|
}
|
|
#fondblanc {
|
|
background-color: #ffffff;
|
|
opacity: 0.9;
|
|
border-radius: 1px;
|
|
box-shadow: 0px 0px 3px 3px #ffffff;
|
|
margin-top: 32px;
|
|
margin-bottom: 3em;
|
|
padding-top: 2em;
|
|
padding-left: 2em;
|
|
padding-right: 2em;
|
|
padding-bottom: 1em;
|
|
}
|
|
</style>
|
|
|
|
<script>
|
|
$(document).ready(function(){
|
|
$('.ui.accordion').accordion();
|
|
var first_season_acc_title = document.getElementsByClassName("title")[0];
|
|
first_season_acc_title.className += " active";
|
|
var first_season_acc_content = document.getElementsByClassName("content")[0];
|
|
first_season_acc_content.className += " active";
|
|
});
|
|
|
|
$(window).on('beforeunload',function(){
|
|
$('#loader').addClass('active');
|
|
});
|
|
</script>
|
|
</head>
|
|
<body>
|
|
%import ast
|
|
%import pycountry
|
|
%from get_general_settings import *
|
|
<div style="display: none;"><img src="{{base_url}}image_proxy{{details[3]}}"></div>
|
|
<div id='loader' class="ui page dimmer">
|
|
<div class="ui indeterminate text loader">Loading...</div>
|
|
</div>
|
|
<div id="divmenu" class="ui container">
|
|
<div style="background-color:#272727;" class="ui inverted borderless labeled icon huge menu five item">
|
|
<a href="{{base_url}}"><img style="margin-right:32px;" class="logo" src="{{base_url}}static/logo128.png"></a>
|
|
<div style="height:80px;" class="ui container">
|
|
<a class="item" href="{{base_url}}">
|
|
<i class="play icon"></i>
|
|
Series
|
|
</a>
|
|
<a class="item" href="{{base_url}}history">
|
|
<i class="wait icon"></i>
|
|
History
|
|
</a>
|
|
<a class="item" href="{{base_url}}wanted">
|
|
<i class="warning sign icon"></i>
|
|
Wanted
|
|
</a>
|
|
<a class="item" href="{{base_url}}settings">
|
|
<i class="settings icon"></i>
|
|
Settings
|
|
</a>
|
|
<a class="item" href="{{base_url}}system">
|
|
<i class="laptop icon"></i>
|
|
System
|
|
</a>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<div style='padding-left: 2em; padding-right: 2em;' class='ui container'>
|
|
<div id="divdetails" class="ui container">
|
|
<img class="left floated ui image" src="{{base_url}}image_proxy{{details[2]}}">
|
|
<div class="ui right floated inverted basic buttons">
|
|
<button id="scan_disk" class="ui button"><i class="refresh icon"></i>Scan disk for subtitles</button>
|
|
<button id="search_missing_subtitles" class="ui button"><i class="download icon"></i>Download missing subtitles</button>
|
|
</div>
|
|
<h2>{{details[0]}}</h2>
|
|
<p>{{details[1]}}</p>
|
|
</div>
|
|
|
|
%if len(seasons) == 0:
|
|
<div id="fondblanc" class="ui container">
|
|
<h3 class="ui header">No episode file available for this series or Bazarr is still synchronizing with Sonarr. Please come back later.</h3>
|
|
</div>
|
|
%else:
|
|
%for season in seasons:
|
|
<div id="fondblanc" class="ui container">
|
|
<h1 class="ui header">Season {{season[0][2]}}</h1>
|
|
<div class="ui accordion">
|
|
<div class="title">
|
|
<div class="ui one column stackable center aligned page grid">
|
|
<div class="column twelve wide">
|
|
<h3 class="ui header"><i class="dropdown icon"></i>
|
|
Show/Hide Episodes</h3>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="content">
|
|
<table class="ui very basic single line selectable table">
|
|
<thead>
|
|
<tr>
|
|
<th class="collapsing">Episode</th>
|
|
<th>Title</th>
|
|
<th class="collapsing">Existing subtitles</th>
|
|
<th class="collapsing">Missing subtitles</th>
|
|
</tr>
|
|
</thead>
|
|
<tbody>
|
|
%for episode in season:
|
|
<tr>
|
|
<td>{{episode[3]}}</td>
|
|
<td>{{episode[0]}}</td>
|
|
<td>
|
|
%if episode[4] is not None:
|
|
% actual_languages = ast.literal_eval(episode[4])
|
|
%else:
|
|
% actual_languages = '[]'
|
|
%end
|
|
|
|
%try:
|
|
%for language in actual_languages:
|
|
%if language[1] is not None:
|
|
<a data-episodePath="{{episode[1]}}" data-subtitlesPath="{{path_replace(language[1])}}" data-language="{{pycountry.languages.lookup(str(language[0])).alpha_3}}" data-sonarrSeriesId={{episode[5]}} data-sonarrEpisodeId={{episode[7]}} class="remove_subtitles ui tiny label">
|
|
{{language[0]}}
|
|
<i class="delete icon"></i>
|
|
</a>
|
|
%else:
|
|
<div class="ui tiny label">
|
|
{{language[0]}}
|
|
</div>
|
|
%end
|
|
%end
|
|
%except:
|
|
%pass
|
|
%end
|
|
</td>
|
|
<td>
|
|
%try:
|
|
%if episode[6] is not None:
|
|
% missing_languages = ast.literal_eval(episode[6])
|
|
%else:
|
|
% missing_languages = None
|
|
%end
|
|
%if missing_languages is not None:
|
|
%for language in missing_languages:
|
|
<a data-episodePath="{{episode[1]}}" data-language="{{pycountry.languages.lookup(str(language)).alpha_3}}" data-hi="{{details[4]}}" data-sonarrSeriesId={{episode[5]}} data-sonarrEpisodeId={{episode[7]}} class="get_subtitle ui tiny label">
|
|
{{language}}
|
|
<i style="margin-left:3px; margin-right:0px" class="search icon"></i>
|
|
</a>
|
|
%end
|
|
%end
|
|
%except:
|
|
%pass
|
|
%end
|
|
</td>
|
|
</tr>
|
|
%end
|
|
</tbody>
|
|
</table>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
%end
|
|
</div>
|
|
</body>
|
|
</html>
|
|
|
|
<script>
|
|
$('#scan_disk').click(function(){
|
|
window.location = '{{base_url}}scan_disk/{{no}}';
|
|
})
|
|
|
|
$('#search_missing_subtitles').click(function(){
|
|
window.location = '{{base_url}}search_missing_subtitles/{{no}}';
|
|
})
|
|
|
|
$('.remove_subtitles').click(function(){
|
|
var values = {
|
|
episodePath: $(this).attr("data-episodePath"),
|
|
language: $(this).attr("data-language"),
|
|
subtitlesPath: $(this).attr("data-subtitlesPath"),
|
|
sonarrSeriesId: $(this).attr("data-sonarrSeriesId"),
|
|
sonarrEpisodeId: $(this).attr("data-sonarrEpisodeId")
|
|
};
|
|
$.ajax({
|
|
url: "{{base_url}}remove_subtitles",
|
|
type: "POST",
|
|
dataType: "json",
|
|
data: values
|
|
});
|
|
$('#loader').addClass('active');
|
|
})
|
|
|
|
$('.get_subtitle').click(function(){
|
|
var values = {
|
|
episodePath: $(this).attr("data-episodePath"),
|
|
language: $(this).attr("data-language"),
|
|
hi: $(this).attr("data-hi"),
|
|
sonarrSeriesId: $(this).attr("data-sonarrSeriesId"),
|
|
sonarrEpisodeId: $(this).attr("data-sonarrEpisodeId")
|
|
};
|
|
$.ajax({
|
|
url: "{{base_url}}get_subtitle",
|
|
type: "POST",
|
|
dataType: "json",
|
|
data: values
|
|
});
|
|
$('#loader').addClass('active');
|
|
})
|
|
|
|
$(document).ajaxStop(function(){
|
|
window.location.reload();
|
|
});
|
|
</script> |