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.
bazarr/views/settings.html

227 lines
9.0 KiB

5 years ago
{% extends '_main.html' %}
{%- from 'settings_general.html' import settings_general with context %}
{%- from 'settings_subtitles.html' import settings_subtitles with context %}
{%- from 'settings_notifications.html' import settings_notifications with context %}
{%- from 'settings_radarr.html' import settings_radarr with context %}
{%- from 'settings_sonarr.html' import settings_sonarr with context %}
{%- from 'providers.html' import settings_providers1 with context %}
{% block title %}Settings - Bazarr{% endblock %}
{% block head %}
<style>
body {
background-color: #272727;
}
#fondblanc {
background-color: #ffffff;
border-radius: 0;
box-shadow: 0 0 5px 5px #ffffff;
margin-top: 32px;
margin-bottom: 3em;
padding: 1em;
}
.ui.tabular.menu > .disabled.item {
opacity: 0.45 !important;
pointer-events: none !important;
}
[data-tooltip]:after {
z-index: 2;
}
</style>
{% endblock head %}
{% block body %}
<div id='loader' class="ui page dimmer">
<div id="loader_text" class="ui indeterminate text loader">Saving settings...</div>
</div>
<div id="fondblanc" class="ui container">
<form name="settings_form" id="settings_form" action="{{ base_url }}save_settings" method="post" class="ui form"
autocomplete="off">
<div id="form_validation_error" class="ui error message">
5 years ago
<p>Some fields are in error and you can't save settings until you have corrected them. Be sure to check
in
every tabs.</p>
</div>
<div class="ui top attached tabular menu">
<a class="tabs item active" data-tab="general">General</a>
<a class="tabs item" id="sonarr_tab" data-tab="sonarr">Sonarr</a>
<a class="tabs item" id="radarr_tab" data-tab="radarr">Radarr</a>
<a class="tabs item" data-tab="subtitles">Subtitles</a>
<a class="tabs item" data-tab="notifier">Notifications</a>
</div>
<div class="ui bottom attached tab segment active" data-tab="general">
5 years ago
<div class="ui container">
<button class="submit ui blue right floated button" type="submit" value="Submit"
form="settings_form">
Save
</button>
</div>
5 years ago
{% include 'settings_general.html' %}
</div>
<div class="ui bottom attached tab segment" data-tab="sonarr">
5 years ago
<div class="ui container">
<button class="submit ui blue right floated button" type="submit" value="Submit"
form="settings_form">
Save
</button>
</div>
5 years ago
{% include 'settings_sonarr.html' %}
</div>
<div class="ui bottom attached tab segment" data-tab="radarr">
5 years ago
<div class="ui container">
<button class="submit ui blue right floated button" type="submit" value="Submit"
form="settings_form">
Save
</button>
</div>
5 years ago
{% include 'settings_radarr.html' %}
</div>
<div class="ui bottom attached tab segment" data-tab="subtitles">
5 years ago
<div class="ui container">
<button class="submit ui blue right floated button" type="submit" value="Submit"
form="settings_form">
Save
</button>
</div>
5 years ago
{% include 'settings_subtitles.html' %}
</div>
<div class="ui bottom attached tab segment" data-tab="notifier">
5 years ago
<div class="ui container">
<button class="submit ui blue right floated button" type="submit" value="Submit"
form="settings_form">
Save
</button>
</div>
5 years ago
{% include 'settings_notifications.html' %}
</div>
5 years ago
</form>
</div>
{% endblock body %}
{% block tail %}
<script src="{{ url_for('static',filename='js/settings_validation.js') }}" type="text/javascript"></script>
<script>
function getQueryVariable(variable) {
var query = window.location.search.substring(1);
var vars = query.split("&");
for (var i = 0; i < vars.length; i++) {
var pair = vars[i].split("=");
if (pair[0] == variable) {
return pair[1];
}
}
return (false);
}
if (getQueryVariable("saved") == 'true') {
new Noty({
text: 'Settings saved.',
timeout: 5000,
progressBar: false,
animation: {
open: null,
close: null
},
killer: true,
type: 'info',
layout: 'bottomRight',
theme: 'semanticui'
}).show();
}
$('.menu .item')
.tab()
;
$('a:not(.tabs), button:not(.cancel, .test, .no_loader)').on('click', function () {
$('#loader').addClass('active');
});
$('a[target="_blank"]').on('click', function () {
$('#loader').removeClass('active');
});
$(function () {
$('.form').form('validate form');
$('#loader').removeClass('active');
});
$(".form :input").on('change paste keyup focusout', function () {
$('.form').form('validate form');
$('#loader').removeClass('active');
});
// Don't move this part to settings_general.tpl as #settings_form is undefined in this template
if ($('#settings_proxy_type').val() === "None") {
$('.proxy_option').hide();
$('#settings_form').form('remove rule', 'settings_proxy_url', 'empty');
$('#settings_form').form('remove rule', 'settings_proxy_port', 'empty');
$('#settings_form').form('remove rule', 'settings_proxy_port', 'integer[1..65535]');
} else {
5 years ago
$('#settings_form').form('add rule', 'settings_proxy_url', {
rules: [{
type: 'empty',
prompt: '"General / Proxy settings / Hostname" must have a value'
}]
});
$('#settings_form').form('add rule', 'settings_proxy_port', {
rules: [{
type: 'empty',
prompt: '"General / Proxy settings / Port" must have a value'
}]
});
$('#settings_form').form('add rule', 'settings_proxy_port', {
rules: [{
type: 'integer[1..65535]',
prompt: '"General / Proxy settings / Port" must be an integer between 1 and 65535'
}]
});
}
5 years ago
// Don't move this part to settings_general.tpl as #settings_form is undefined in this template
$('#settings_proxy_type').dropdown('setting', 'onChange', function () {
if ($('#settings_proxy_type').val() === "None") {
$('.proxy_option').hide();
$('#settings_form').form('remove rule', 'settings_proxy_url', 'empty');
$('#settings_form').form('remove rule', 'settings_proxy_port', 'empty');
$('#settings_form').form('remove rule', 'settings_proxy_port', 'integer[1..65535]');
$('.form').form('validate form');
$('#loader').removeClass('active');
} else {
$('.proxy_option').show();
$('#settings_form').form('add rule', 'settings_proxy_url', {
rules: [{
type: 'empty',
prompt: '"General / Proxy settings / Hostname" must have a value'
}]
});
$('#settings_form').form('add rule', 'settings_proxy_port', {
rules: [{
type: 'empty',
prompt: '"General / Proxy settings / Port" must have a value'
}]
});
$('#settings_form').form('add rule', 'settings_proxy_port', {
rules: [{
type: 'integer[1..65535]',
prompt: '"General / Proxy settings / Port" must be an integer between 1 and 65535'
}]
});
$('.form').form('validate form');
$('#loader').removeClass('active');
}
});
</script>
{{ settings_general() }}
{{ settings_subtitles() }}
{{ settings_notifications() }}
{{ settings_radarr() }}
{{ settings_sonarr() }}
{{ settings_providers1() }}
{% endblock tail %}