bazarr/views/menu.tpl

242 lines
7.8 KiB
Python
Raw Normal View History

<html lang="en">
2017-12-22 08:49:39 +08:00
<head>
<!DOCTYPE html>
2018-12-13 10:50:05 +08:00
<link href="{{base_url}}static/noty/noty.css" rel="stylesheet">
<script src="{{base_url}}static/noty/noty.min.js" type="text/javascript"></script>
2017-12-22 08:49:39 +08:00
<style>
#divmenu {
2017-12-22 11:36:22 +08:00
background-color: #000000;
2017-12-22 08:49:39 +08:00
padding-top: 2em;
padding-bottom: 1em;
padding-left: 1em;
padding-right: 128px;
}
.prompt {
background-color: #333333 !important;
color: white !important;
border-radius: 3px !important;
}
2017-12-23 12:16:50 +08:00
.searchicon {
color: white !important;
}
2017-12-22 08:49:39 +08:00
</style>
</head>
<body>
% from get_args import args
% import os
% import sqlite3
2018-12-15 08:36:28 +08:00
% from config import settings
2019-01-07 01:15:43 +08:00
%if settings.sonarr.getboolean('only_monitored'):
% monitored_only_query_string_sonarr = ' AND monitored = "True"'
%else:
2019-01-07 01:15:43 +08:00
% monitored_only_query_string_sonarr = ""
%end
%if settings.radarr.getboolean('only_monitored'):
% monitored_only_query_string_radarr = ' AND monitored = "True"'
%else:
% monitored_only_query_string_radarr = ""
%end
% conn = sqlite3.connect(os.path.join(args.config_dir, 'db', 'bazarr.db'), timeout=30)
% c = conn.cursor()
2019-01-07 01:15:43 +08:00
% wanted_series = c.execute("SELECT COUNT(*) FROM table_episodes WHERE missing_subtitles != '[]'" + monitored_only_query_string_sonarr).fetchone()
% wanted_movies = c.execute("SELECT COUNT(*) FROM table_movies WHERE missing_subtitles != '[]'" + monitored_only_query_string_radarr).fetchone()
<div id="divmenu" class="ui container">
2017-12-22 08:49:39 +08:00
<div class="ui grid">
<div class="middle aligned row">
<div class="three wide column">
<a href="{{base_url}}"><img class="logo" src="{{base_url}}static/logo128.png"></a>
</div>
<div class="twelve wide column">
<div class="ui grid">
<div class="row">
<div class="sixteen wide column">
2018-04-20 07:45:10 +08:00
<div class="ui inverted borderless labeled icon massive menu six item">
2017-12-22 08:49:39 +08:00
<div class="ui container">
% if settings.general.getboolean('use_sonarr'):
<a class="item" href="{{base_url}}series">
2017-12-22 08:49:39 +08:00
<i class="play icon"></i>
Series
</a>
% end
% if settings.general.getboolean('use_radarr'):
2018-04-20 07:45:10 +08:00
<a class="item" href="{{base_url}}movies">
<i class="film icon"></i>
Movies
</a>
% end
2017-12-22 08:49:39 +08:00
<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">
% if settings.general.getboolean('use_sonarr'):
2018-05-02 18:25:42 +08:00
<div class="floating ui tiny yellow label" style="left:90% !important;top:0.5em !important;">
{{wanted_series[0]}}
</div>
% end
% if settings.general.getboolean('use_radarr'):
2018-05-02 18:25:42 +08:00
<div class="floating ui tiny green label" style="left:90% !important;top:3em !important;">
{{wanted_movies[0]}}
</div>
% end
</i>
2017-12-22 08:49:39 +08:00
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>
<div style='padding-top:0;' class="row">
2017-12-22 08:49:39 +08:00
<div class="three wide column"></div>
<div class="ten wide column">
<div class="ui search">
<div class="ui left icon fluid input">
<input class="prompt" type="text" placeholder="Search in your library">
2017-12-23 12:16:50 +08:00
<i class="searchicon search icon"></i>
2017-12-22 08:49:39 +08:00
</div>
</div>
</div>
<div class="three wide column"></div>
</div>
</div>
</div>
</div>
</div>
2018-09-27 23:50:48 +08:00
% restart_required = c.execute("SELECT configured, updated FROM system").fetchone()
% c.close()
2018-09-27 23:50:48 +08:00
% if restart_required[1] == '1' and restart_required[0] == '1':
<div class='ui center aligned grid'><div class='fifteen wide column'><div class="ui red message">Bazarr need to be restarted to apply last update and changes to general settings. Click <a href=# id="restart_link">here</a> to restart.</div></div></div>
2018-09-27 23:50:48 +08:00
% elif restart_required[1] == '1':
<div class='ui center aligned grid'><div class='fifteen wide column'><div class="ui red message">Bazarr need to be restarted to apply last update. Click <a href=# id="restart_link">here</a> to restart.</div></div></div>
2018-09-27 23:50:48 +08:00
% elif restart_required[0] == '1':
<div class='ui center aligned grid'><div class='fifteen wide column'><div class="ui red message">Bazarr need to be restarted to apply changes to general settings. Click <a href=# id="restart_link">here</a> to restart.</div></div></div>
2018-09-27 23:50:48 +08:00
% end
</div>
2017-12-22 08:49:39 +08:00
</body>
</html>
<script>
$('.ui.search')
.search({
apiSettings: {
2018-04-24 22:48:52 +08:00
url: '{{base_url}}search_json/{query}',
2017-12-22 08:49:39 +08:00
onResponse: function(results) {
const response = {
2017-12-22 08:49:39 +08:00
results : []
};
$.each(results.items, function(index, item) {
response.results.push({
title : item.name,
url : item.url
});
});
return response;
}
},
minCharacters : 2
})
;
2017-12-22 11:36:22 +08:00
if (window.location.href.indexOf("episodes") > -1) {
$('.menu').css('background', '#000000');
2018-09-28 22:40:36 +08:00
$('.menu').css('opacity', '0.8');
2017-12-22 11:36:22 +08:00
$('#divmenu').css('background', '#000000');
2018-09-28 22:40:36 +08:00
$('#divmenu').css('opacity', '0.8');
$('#divmenu').css('box-shadow', '0 0 5px 5px #000000');
2018-09-28 22:40:36 +08:00
}
else if (window.location.href.indexOf("movie/") > -1) {
$('.menu').css('background', '#000000');
$('.menu').css('opacity', '0.8');
$('#divmenu').css('background', '#000000');
$('#divmenu').css('opacity', '0.8');
$('#divmenu').css('box-shadow', '0 0 5px 5px #000000');
2017-12-22 11:36:22 +08:00
}
else {
$('.menu').css('background', '#272727');
$('#divmenu').css('background', '#272727');
}
$('#restart_link').on('click', function(){
$('#loader_text').text("Bazarr is restarting, please wait...");
$.ajax({
url: "{{base_url}}restart",
async: true
})
.done(function(){
setTimeout(function(){ setInterval(ping, 2000); },8000);
});
});
2018-12-15 08:36:28 +08:00
% from config import settings
% ip = settings.general.ip
% port = settings.general.port
% base_url = settings.general.base_url
2018-10-16 22:58:25 +08:00
if ("{{ip}}" === "0.0.0.0") {
2018-10-16 22:58:25 +08:00
public_ip = window.location.hostname;
} else {
public_ip = "{{ip}}";
}
protocol = window.location.protocol;
if (window.location.port === '{{current_port}}') {
public_port = '{{port}}';
} else {
public_port = window.location.port;
}
function ping() {
$.ajax({
url: protocol + '//' + public_ip + ':' + public_port + '{{base_url}}',
success: function(result) {
window.location.href= protocol + '//' + public_ip + ':' + public_port + '{{base_url}}';
}
});
}
2018-11-30 10:24:48 +08:00
</script>
<script type="text/javascript">
if (location.protocol != 'https:')
{
var ws = new WebSocket("ws://" + window.location.host + "{{base_url}}websocket");
} else {
var ws = new WebSocket("wss://" + window.location.host + "{{base_url}}websocket");
}
2018-11-30 10:24:48 +08:00
ws.onmessage = function (evt) {
2018-12-13 10:50:05 +08:00
new Noty({
text: evt.data,
timeout: 3000,
2018-12-14 19:52:09 +08:00
progressBar: false,
animation: {
open: null,
close: null
},
killer: true,
2018-12-14 22:28:14 +08:00
type: 'info',
2018-12-13 10:50:05 +08:00
layout: 'bottomRight',
theme: 'semanticui'
}).show();
2018-11-30 10:24:48 +08:00
};
2017-12-22 08:49:39 +08:00
</script>