2018-05-22 16:40:05 +00:00
|
|
|
var settings = [];
|
|
|
|
|
|
|
|
var core = function (func) {
|
|
|
|
return browser.runtime.getBackgroundPage().then(func);
|
|
|
|
};
|
|
|
|
|
|
|
|
getData();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Load only when document is ready
|
|
|
|
*/
|
|
|
|
$(document).ready(function(){
|
|
|
|
setText();
|
|
|
|
$(".pick-a-color").pickAColor();
|
|
|
|
$('#reset_settings_btn').on("click", reset);
|
|
|
|
$('#save_settings_btn').on("click", save);
|
|
|
|
|
|
|
|
$("#badged_color input").on("change", function () {
|
|
|
|
settings.badged_color = $(this).val();
|
|
|
|
core(function (ref){
|
|
|
|
ref.setData('badged_color', settings.badged_color);
|
|
|
|
ref.setBadgedStatus();
|
|
|
|
ref.saveOnExit();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Reset everything.
|
|
|
|
* Set everthing to the default values.
|
|
|
|
*/
|
|
|
|
function reset()
|
|
|
|
{
|
|
|
|
core(function (ref){
|
|
|
|
ref.initSettings();
|
|
|
|
ref.saveOnExit();
|
|
|
|
ref.reload();
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Saves the settings.
|
|
|
|
*/
|
|
|
|
function save()
|
|
|
|
{
|
|
|
|
core(function (ref){
|
2018-06-19 16:13:44 +00:00
|
|
|
ref.setData('badged_color', $('input[name=badged_color]').val());
|
|
|
|
ref.setBadgedStatus();
|
2018-05-22 16:40:05 +00:00
|
|
|
ref.setData('ruleURL', $('input[name=rule_url]').val());
|
|
|
|
ref.setData('hashURL', $('input[name=hash_url]').val());
|
2018-07-31 17:15:48 +00:00
|
|
|
ref.setData('types', $('input[name=types]').val());
|
2018-05-22 16:40:05 +00:00
|
|
|
ref.saveOnExit();
|
|
|
|
ref.reload();
|
|
|
|
});
|
|
|
|
|
|
|
|
location.reload();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Translate a string with the i18n API.
|
|
|
|
*
|
|
|
|
* @param {string} string Name of the attribute used for localization
|
|
|
|
*/
|
|
|
|
function translate(string)
|
|
|
|
{
|
|
|
|
return browser.i18n.getMessage(string);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the data.
|
|
|
|
*/
|
|
|
|
function getData()
|
|
|
|
{
|
|
|
|
core(function (ref){
|
|
|
|
settings.badged_color = ref.getData('badged_color');
|
|
|
|
settings.rule_url = ref.getData('ruleURL');
|
|
|
|
settings.hash_url = ref.getData('hashURL');
|
2018-07-31 17:15:48 +00:00
|
|
|
settings.types = ref.getData('types');
|
2018-05-22 16:40:05 +00:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the text for the UI.
|
|
|
|
*/
|
|
|
|
function setText()
|
|
|
|
{
|
|
|
|
document.title = translate('settings_html_page_title');
|
|
|
|
$('#page_title').text(translate('settings_html_page_title'));
|
|
|
|
$('#badged_color_label').text(translate('badged_color_label'));
|
|
|
|
$('input[name=badged_color]').val(settings.badged_color);
|
|
|
|
$('#reset_settings_btn').text(translate('setting_html_reset_button'));
|
|
|
|
$('#reset_settings_btn').prop('title', translate('setting_html_reset_button_title'));
|
|
|
|
$('#rule_url_label').text(translate('setting_rule_url_label'));
|
|
|
|
$('input[name=rule_url]').val(settings.rule_url);
|
|
|
|
$('#hash_url_label').text(translate('setting_hash_url_label'));
|
|
|
|
$('input[name=hash_url]').val(settings.hash_url);
|
2018-07-31 17:15:48 +00:00
|
|
|
$('#types_label').html(translate('setting_types_label'));
|
|
|
|
$('input[name=types]').val(settings.types);
|
2018-05-22 16:40:05 +00:00
|
|
|
$('#save_settings_btn').text(translate('settings_html_save_button'));
|
|
|
|
$('#save_settings_btn').prop('title', translate('settings_html_save_button_title'));
|
|
|
|
}
|