mirror of
https://github.com/gorhill/uBlock.git
synced 2024-11-10 09:07:54 +01:00
these also suffered from issue #307
This commit is contained in:
parent
96d4643f4c
commit
dbd36b24a0
4 changed files with 53 additions and 43 deletions
|
@ -13,6 +13,7 @@
|
||||||
<div>
|
<div>
|
||||||
<p data-i18n="1pFormatHint"></p>
|
<p data-i18n="1pFormatHint"></p>
|
||||||
<p><button id="importUserFiltersFromFile" data-i18n="1pImport"></button>   <button id="exportUserFiltersToFile" data-i18n="1pExport"></button></p>
|
<p><button id="importUserFiltersFromFile" data-i18n="1pImport"></button>   <button id="exportUserFiltersToFile" data-i18n="1pExport"></button></p>
|
||||||
|
<input id="importFilePicker" type="file" accept="text/plain" style="display:none;">
|
||||||
<textarea class="userFilters" id="userFilters" dir="auto" spellcheck="false"></textarea>
|
<textarea class="userFilters" id="userFilters" dir="auto" spellcheck="false"></textarea>
|
||||||
<p><button id="userFiltersApply" disabled="true" data-i18n="1pApplyChanges"></button></p>
|
<p><button id="userFiltersApply" disabled="true" data-i18n="1pApplyChanges"></button></p>
|
||||||
</div>
|
</div>
|
||||||
|
|
|
@ -37,7 +37,7 @@ messaging.start('1p-filters.js');
|
||||||
|
|
||||||
// This is to give a visual hint that the content of user blacklist has changed.
|
// This is to give a visual hint that the content of user blacklist has changed.
|
||||||
|
|
||||||
function userFiltersChanged(ev) {
|
function userFiltersChanged() {
|
||||||
uDom('#userFiltersApply').prop(
|
uDom('#userFiltersApply').prop(
|
||||||
'disabled',
|
'disabled',
|
||||||
uDom('#userFilters').val().trim() === cachedUserFilters
|
uDom('#userFilters').val().trim() === cachedUserFilters
|
||||||
|
@ -66,35 +66,37 @@ function allFiltersApplyHandler() {
|
||||||
|
|
||||||
/******************************************************************************/
|
/******************************************************************************/
|
||||||
|
|
||||||
function appendToUserFiltersFromFile() {
|
function handleImportFilePicker() {
|
||||||
var input = uDom('<input />').attr({
|
|
||||||
type: 'file',
|
|
||||||
accept: 'text/plain'
|
|
||||||
});
|
|
||||||
var fileReaderOnLoadHandler = function() {
|
var fileReaderOnLoadHandler = function() {
|
||||||
var textarea = uDom('#userFilters');
|
var textarea = uDom('#userFilters');
|
||||||
textarea.val([textarea.val(), this.result].join('\n').trim());
|
textarea.val([textarea.val(), this.result].join('\n').trim());
|
||||||
userFiltersChanged();
|
userFiltersChanged();
|
||||||
};
|
};
|
||||||
var filePickerOnChangeHandler = function() {
|
var file = this.files[0];
|
||||||
var file = this.files[0];
|
if ( file === undefined || file.name === '' ) {
|
||||||
if ( !file ) {
|
return;
|
||||||
return;
|
}
|
||||||
}
|
if ( file.type.indexOf('text') !== 0 ) {
|
||||||
if ( file.type.indexOf('text') !== 0 ) {
|
return;
|
||||||
return;
|
}
|
||||||
}
|
var fr = new FileReader();
|
||||||
var fr = new FileReader();
|
fr.onload = fileReaderOnLoadHandler;
|
||||||
fr.onload = fileReaderOnLoadHandler;
|
fr.readAsText(file);
|
||||||
fr.readAsText(file);
|
|
||||||
input.off('change', filePickerOnChangeHandler);
|
|
||||||
};
|
|
||||||
input.on('change', filePickerOnChangeHandler);
|
|
||||||
input.trigger('click');
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/******************************************************************************/
|
/******************************************************************************/
|
||||||
|
|
||||||
|
var startImportFilePicker = function() {
|
||||||
|
var input = document.getElementById('importFilePicker');
|
||||||
|
// Reset to empty string, this will ensure an change event is properly
|
||||||
|
// triggered if the user pick a file, even if it is the same as the last
|
||||||
|
// one picked.
|
||||||
|
input.value = '';
|
||||||
|
input.click();
|
||||||
|
};
|
||||||
|
|
||||||
|
/******************************************************************************/
|
||||||
|
|
||||||
function exportUserFiltersToFile() {
|
function exportUserFiltersToFile() {
|
||||||
chrome.downloads.download({
|
chrome.downloads.download({
|
||||||
'url': 'data:text/plain,' + encodeURIComponent(uDom('#userFilters').val()),
|
'url': 'data:text/plain,' + encodeURIComponent(uDom('#userFilters').val()),
|
||||||
|
@ -125,7 +127,8 @@ function userFiltersApplyHandler() {
|
||||||
|
|
||||||
uDom.onLoad(function() {
|
uDom.onLoad(function() {
|
||||||
// Handle user interaction
|
// Handle user interaction
|
||||||
uDom('#importUserFiltersFromFile').on('click', appendToUserFiltersFromFile);
|
uDom('#importUserFiltersFromFile').on('click', startImportFilePicker);
|
||||||
|
uDom('#importFilePicker').on('change', handleImportFilePicker);
|
||||||
uDom('#exportUserFiltersToFile').on('click', exportUserFiltersToFile);
|
uDom('#exportUserFiltersToFile').on('click', exportUserFiltersToFile);
|
||||||
uDom('#userFilters').on('input', userFiltersChanged);
|
uDom('#userFilters').on('input', userFiltersChanged);
|
||||||
uDom('#userFiltersApply').on('click', userFiltersApplyHandler);
|
uDom('#userFiltersApply').on('click', userFiltersApplyHandler);
|
||||||
|
@ -135,5 +138,7 @@ uDom.onLoad(function() {
|
||||||
|
|
||||||
/******************************************************************************/
|
/******************************************************************************/
|
||||||
|
|
||||||
|
// https://www.youtube.com/watch?v=UNilsLf6eW4
|
||||||
|
|
||||||
})();
|
})();
|
||||||
|
|
||||||
|
|
|
@ -60,31 +60,33 @@ var renderWhitelist = function() {
|
||||||
|
|
||||||
/******************************************************************************/
|
/******************************************************************************/
|
||||||
|
|
||||||
var importWhitelistFromFile = function() {
|
var handleImportFilePicker = function() {
|
||||||
var input = uDom('<input />').attr({
|
|
||||||
type: 'file',
|
|
||||||
accept: 'text/plain'
|
|
||||||
});
|
|
||||||
var fileReaderOnLoadHandler = function() {
|
var fileReaderOnLoadHandler = function() {
|
||||||
var textarea = uDom('#whitelist');
|
var textarea = uDom('#whitelist');
|
||||||
textarea.val([textarea.val(), this.result].join('\n').trim());
|
textarea.val([textarea.val(), this.result].join('\n').trim());
|
||||||
whitelistChanged();
|
whitelistChanged();
|
||||||
};
|
};
|
||||||
var filePickerOnChangeHandler = function() {
|
var file = this.files[0];
|
||||||
input.off('change', filePickerOnChangeHandler);
|
if ( file === undefined || file.name === '' ) {
|
||||||
var file = this.files[0];
|
return;
|
||||||
if ( !file ) {
|
}
|
||||||
return;
|
if ( file.type.indexOf('text') !== 0 ) {
|
||||||
}
|
return;
|
||||||
if ( file.type.indexOf('text') !== 0 ) {
|
}
|
||||||
return;
|
var fr = new FileReader();
|
||||||
}
|
fr.onload = fileReaderOnLoadHandler;
|
||||||
var fr = new FileReader();
|
fr.readAsText(file);
|
||||||
fr.onload = fileReaderOnLoadHandler;
|
};
|
||||||
fr.readAsText(file);
|
|
||||||
};
|
/******************************************************************************/
|
||||||
input.on('change', filePickerOnChangeHandler);
|
|
||||||
input.trigger('click');
|
var startImportFilePicker = function() {
|
||||||
|
var input = document.getElementById('importFilePicker');
|
||||||
|
// Reset to empty string, this will ensure an change event is properly
|
||||||
|
// triggered if the user pick a file, even if it is the same as the last
|
||||||
|
// one picked.
|
||||||
|
input.value = '';
|
||||||
|
input.click();
|
||||||
};
|
};
|
||||||
|
|
||||||
/******************************************************************************/
|
/******************************************************************************/
|
||||||
|
@ -112,7 +114,8 @@ var whitelistApplyHandler = function() {
|
||||||
/******************************************************************************/
|
/******************************************************************************/
|
||||||
|
|
||||||
uDom.onLoad(function() {
|
uDom.onLoad(function() {
|
||||||
uDom('#importWhitelistFromFile').on('click', importWhitelistFromFile);
|
uDom('#importWhitelistFromFile').on('click', startImportFilePicker);
|
||||||
|
uDom('#importFilePicker').on('change', handleImportFilePicker);
|
||||||
uDom('#exportWhitelistToFile').on('click', exportWhitelistToFile);
|
uDom('#exportWhitelistToFile').on('click', exportWhitelistToFile);
|
||||||
uDom('#whitelist').on('input', whitelistChanged);
|
uDom('#whitelist').on('input', whitelistChanged);
|
||||||
uDom('#whitelistApply').on('click', whitelistApplyHandler);
|
uDom('#whitelistApply').on('click', whitelistApplyHandler);
|
||||||
|
|
|
@ -13,6 +13,7 @@
|
||||||
<div>
|
<div>
|
||||||
<p data-i18n="whitelistPrompt"></p>
|
<p data-i18n="whitelistPrompt"></p>
|
||||||
<p><button id="importWhitelistFromFile" data-i18n="whitelistImport"></button>   <button id="exportWhitelistToFile" data-i18n="whitelistExport"></button></p>
|
<p><button id="importWhitelistFromFile" data-i18n="whitelistImport"></button>   <button id="exportWhitelistToFile" data-i18n="whitelistExport"></button></p>
|
||||||
|
<input id="importFilePicker" type="file" accept="text/plain" style="display:none;">
|
||||||
<textarea id="whitelist" dir="auto" spellcheck="false"></textarea>
|
<textarea id="whitelist" dir="auto" spellcheck="false"></textarea>
|
||||||
<p><button id="whitelistApply" type="button" disabled="true" data-i18n="whitelistApply"></button></p>
|
<p><button id="whitelistApply" type="button" disabled="true" data-i18n="whitelistApply"></button></p>
|
||||||
</div>
|
</div>
|
||||||
|
|
Loading…
Reference in a new issue