2020-07-17 19:04:56 +01:00
|
|
|
import loading from 'loading';
|
|
|
|
import 'emby-checkbox';
|
|
|
|
import 'emby-button';
|
|
|
|
import 'emby-select';
|
2018-10-23 01:05:09 +03:00
|
|
|
|
2020-07-17 19:04:56 +01:00
|
|
|
function save(page) {
|
|
|
|
loading.show();
|
|
|
|
const apiClient = ApiClient;
|
|
|
|
apiClient.getJSON(apiClient.getUrl('Startup/Configuration')).then(function (config) {
|
|
|
|
config.PreferredMetadataLanguage = page.querySelector('#selectLanguage').value;
|
|
|
|
config.MetadataCountryCode = page.querySelector('#selectCountry').value;
|
|
|
|
apiClient.ajax({
|
|
|
|
type: 'POST',
|
2020-08-12 21:17:07 +02:00
|
|
|
data: JSON.stringify(config),
|
2020-07-17 19:04:56 +01:00
|
|
|
url: apiClient.getUrl('Startup/Configuration')
|
|
|
|
}).then(function () {
|
|
|
|
loading.hide();
|
|
|
|
navigateToNextPage();
|
2019-10-08 01:28:44 +03:00
|
|
|
});
|
2020-07-17 19:04:56 +01:00
|
|
|
});
|
|
|
|
}
|
2019-10-08 01:28:44 +03:00
|
|
|
|
2020-07-17 19:04:56 +01:00
|
|
|
function populateLanguages(select, languages) {
|
|
|
|
let html = '';
|
|
|
|
html += "<option value=''></option>";
|
2019-10-08 01:28:44 +03:00
|
|
|
|
2020-07-17 19:04:56 +01:00
|
|
|
for (let i = 0, length = languages.length; i < length; i++) {
|
|
|
|
const culture = languages[i];
|
|
|
|
html += "<option value='" + culture.TwoLetterISOLanguageName + "'>" + culture.DisplayName + '</option>';
|
2018-10-23 01:05:09 +03:00
|
|
|
}
|
|
|
|
|
2020-07-17 19:04:56 +01:00
|
|
|
select.innerHTML = html;
|
|
|
|
}
|
2019-10-08 01:28:44 +03:00
|
|
|
|
2020-07-17 19:04:56 +01:00
|
|
|
function populateCountries(select, allCountries) {
|
|
|
|
let html = '';
|
|
|
|
html += "<option value=''></option>";
|
2019-10-08 01:28:44 +03:00
|
|
|
|
2020-07-17 19:04:56 +01:00
|
|
|
for (let i = 0, length = allCountries.length; i < length; i++) {
|
|
|
|
const culture = allCountries[i];
|
|
|
|
html += "<option value='" + culture.TwoLetterISORegionName + "'>" + culture.DisplayName + '</option>';
|
2018-10-23 01:05:09 +03:00
|
|
|
}
|
|
|
|
|
2020-07-17 19:04:56 +01:00
|
|
|
select.innerHTML = html;
|
|
|
|
}
|
2018-10-23 01:05:09 +03:00
|
|
|
|
2020-07-17 19:04:56 +01:00
|
|
|
function reloadData(page, config, cultures, countries) {
|
|
|
|
populateLanguages(page.querySelector('#selectLanguage'), cultures);
|
|
|
|
populateCountries(page.querySelector('#selectCountry'), countries);
|
|
|
|
page.querySelector('#selectLanguage').value = config.PreferredMetadataLanguage;
|
|
|
|
page.querySelector('#selectCountry').value = config.MetadataCountryCode;
|
|
|
|
loading.hide();
|
|
|
|
}
|
2018-10-23 01:05:09 +03:00
|
|
|
|
2020-07-17 19:04:56 +01:00
|
|
|
function reload(page) {
|
|
|
|
loading.show();
|
|
|
|
const apiClient = ApiClient;
|
|
|
|
const promise1 = apiClient.getJSON(apiClient.getUrl('Startup/Configuration'));
|
|
|
|
const promise2 = apiClient.getCultures();
|
|
|
|
const promise3 = apiClient.getCountries();
|
|
|
|
Promise.all([promise1, promise2, promise3]).then(function (responses) {
|
|
|
|
reloadData(page, responses[0], responses[1], responses[2]);
|
|
|
|
});
|
|
|
|
}
|
2018-10-23 01:05:09 +03:00
|
|
|
|
2020-07-17 19:04:56 +01:00
|
|
|
function navigateToNextPage() {
|
|
|
|
Dashboard.navigate('wizardremoteaccess.html');
|
|
|
|
}
|
2019-10-08 01:28:44 +03:00
|
|
|
|
2020-07-17 19:04:56 +01:00
|
|
|
function onSubmit(e) {
|
|
|
|
save(this);
|
|
|
|
e.preventDefault();
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
export default function (view, params) {
|
|
|
|
view.querySelector('.wizardSettingsForm').addEventListener('submit', onSubmit);
|
|
|
|
view.addEventListener('viewshow', function () {
|
|
|
|
document.querySelector('.skinHeader').classList.add('noHomeButtonHeader');
|
|
|
|
reload(this);
|
|
|
|
});
|
|
|
|
view.addEventListener('viewhide', function () {
|
|
|
|
document.querySelector('.skinHeader').classList.remove('noHomeButtonHeader');
|
|
|
|
});
|
|
|
|
}
|