1
0
Fork 0
mirror of https://github.com/gorhill/uMatrix.git synced 2024-07-02 13:00:44 +12:00
uMatrix/src/js/settings.js

132 lines
4.4 KiB
JavaScript
Raw Normal View History

2014-10-18 08:01:09 +13:00
/*******************************************************************************
µMatrix - a Chromium browser extension to black/white list requests.
Copyright (C) 2014 Raymond Hill
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see {http://www.gnu.org/licenses/}.
Home: https://github.com/gorhill/uMatrix
*/
/******************************************************************************/
(function() {
/******************************************************************************/
messaging.start('settings.js');
var cachedUserSettings = {};
/******************************************************************************/
var subframeDemoBackgroundImage = 'repeating-linear-gradient(\
-45deg,\
{{color}},{{color}} 24%,\
transparent 26%,transparent 49%,\
{{color}} 51%,{{color}} 74%,\
transparent 76%,transparent\
)';
var updateSubframeDemo = function() {
2014-10-25 10:22:32 +13:00
var demo = uDom('#subframe-color-demo');
var color = uDom('#subframe-color').val();
2014-10-18 08:01:09 +13:00
demo.css('border-color', color);
var re = new RegExp('\{\{color\}\}', 'g');
demo.css('background-image', subframeDemoBackgroundImage.replace(re, color));
2014-10-25 10:22:32 +13:00
demo.css('opacity', (parseInt(uDom('#subframe-opacity').val(), 10) / 100).toFixed(1));
2014-10-18 08:01:09 +13:00
};
var onSubframeColorChanged = function() {
2014-10-25 10:22:32 +13:00
var color = uDom('#subframe-color').val();
2014-10-18 08:01:09 +13:00
if ( color === '' ) {
2014-10-25 10:22:32 +13:00
uDom('#subframe-color').val(color);
2014-10-18 08:01:09 +13:00
}
changeUserSettings('subframeColor', color);
2014-10-25 10:22:32 +13:00
var opacity = parseInt(uDom('#subframe-opacity').val(), 10);
2014-10-18 08:01:09 +13:00
if ( Number.isNaN(opacity) ) {
opacity = 100;
}
changeUserSettings('subframeOpacity', opacity);
updateSubframeDemo();
};
/******************************************************************************/
function changeUserSettings(name, value) {
messaging.tell({
what: 'userSettings',
name: name,
value: value
});
}
/******************************************************************************/
function prepareToDie() {
onSubframeColorChanged();
}
/******************************************************************************/
var installEventHandlers = function() {
// `data-range` allows to add/remove bool properties without
// changing code.
2014-10-25 10:22:32 +13:00
uDom('input[data-range="bool"]').on('change', function() {
2014-10-18 08:01:09 +13:00
changeUserSettings(this.id, this.checked);
});
2014-10-25 10:22:32 +13:00
uDom('input[name="displayTextSize"]').on('change', function(){
changeUserSettings('displayTextSize', this.value);
2014-10-18 08:01:09 +13:00
});
2014-10-25 10:22:32 +13:00
uDom('#smart-auto-reload').on('change', function(){
2014-10-18 08:01:09 +13:00
changeUserSettings('smartAutoReload', this.value);
});
2014-10-25 10:22:32 +13:00
uDom('#subframe-color').on('change', function(){ onSubframeColorChanged(); });
uDom('#subframe-opacity').on('change', function(){ onSubframeColorChanged(); });
2014-10-18 08:01:09 +13:00
// https://github.com/gorhill/httpswitchboard/issues/197
2014-10-25 10:22:32 +13:00
uDom(window).on('beforeunload', prepareToDie);
2014-10-18 08:01:09 +13:00
};
/******************************************************************************/
2014-10-25 10:22:32 +13:00
uDom.onLoad(function() {
2014-10-18 08:01:09 +13:00
var onUserSettingsReceived = function(userSettings) {
// Cache copy
cachedUserSettings = userSettings;
// `data-range` allows to add/remove bool properties without
// changing code.
2014-10-25 10:22:32 +13:00
uDom('input[data-range="bool"]').toArray().forEach(function(elem) {
elem.checked = userSettings[elem.id] === true;
2014-10-18 08:01:09 +13:00
});
2014-10-25 10:22:32 +13:00
uDom('input[name="displayTextSize"]').toArray().forEach(function(elem) {
elem.checked = elem.value === userSettings.displayTextSize;
});
uDom('#smart-auto-reload').val(userSettings.smartAutoReload);
uDom('#subframe-color').val(userSettings.subframeColor);
uDom('#subframe-opacity').val(userSettings.subframeOpacity);
2014-10-18 08:01:09 +13:00
updateSubframeDemo();
installEventHandlers();
};
messaging.ask({ what: 'getUserSettings' }, onUserSettingsReceived);
});
/******************************************************************************/
})();