mirror of
https://github.com/gorhill/uBlock.git
synced 2024-11-20 01:12:38 +01:00
this fixes #792
This commit is contained in:
parent
6312e98cfe
commit
ed88939a63
@ -83,6 +83,15 @@ vAPI.closePopup = function() {
|
||||
|
||||
/******************************************************************************/
|
||||
|
||||
// A localStorage-like object which should be accessible from the
|
||||
// background page or auxiliary pages.
|
||||
// This storage is optional, but it is nice to have, for a more polished user
|
||||
// experience.
|
||||
|
||||
vAPI.localStorage = window.localStorage;
|
||||
|
||||
/******************************************************************************/
|
||||
|
||||
})();
|
||||
|
||||
/******************************************************************************/
|
||||
|
@ -109,6 +109,20 @@ vAPI.closePopup = function() {
|
||||
|
||||
/******************************************************************************/
|
||||
|
||||
// A localStorage-like object which should be accessible from the
|
||||
// background page or auxiliary pages.
|
||||
// This storage is optional, but it is nice to have, for a more polished user
|
||||
// experience.
|
||||
|
||||
vAPI.localStorage = {
|
||||
key: function(){},
|
||||
getItem: function(){},
|
||||
setItem: function(){},
|
||||
removeItem: function(){}
|
||||
};
|
||||
|
||||
/******************************************************************************/
|
||||
|
||||
})();
|
||||
|
||||
/******************************************************************************/
|
||||
|
@ -128,4 +128,18 @@ vAPI.closePopup = function() {
|
||||
}
|
||||
};
|
||||
|
||||
/******************************************************************************/
|
||||
|
||||
// A localStorage-like object which should be accessible from the
|
||||
// background page or auxiliary pages.
|
||||
// This storage is optional, but it is nice to have, for a more polished user
|
||||
// experience.
|
||||
|
||||
vAPI.localStorage = {
|
||||
key: function(){},
|
||||
getItem: function(){},
|
||||
setItem: function(){},
|
||||
removeItem: function(){}
|
||||
};
|
||||
|
||||
})();
|
||||
|
@ -22,12 +22,24 @@ body[dir=rtl] #lists {
|
||||
padding: 0;
|
||||
list-style-type: none;
|
||||
}
|
||||
#lists > li > span {
|
||||
#lists > .groupEntry > span {
|
||||
cursor: pointer;
|
||||
font-size: 15px;
|
||||
}
|
||||
#lists > li > ul {
|
||||
#lists > .groupEntry:not(:first-child) > span:before {
|
||||
color: #aaa;
|
||||
content: '\2212 ';
|
||||
}
|
||||
#lists > .groupEntry.collapsed > span:before {
|
||||
color: #aaa;
|
||||
content: '+ ';
|
||||
}
|
||||
#lists > .groupEntry > ul {
|
||||
margin: 0.25em 0 0 0;
|
||||
}
|
||||
#lists > .groupEntry.collapsed > ul {
|
||||
display: none;
|
||||
}
|
||||
li.listEntry {
|
||||
font-size: 14px;
|
||||
margin: 0 auto 0 auto;
|
||||
|
@ -185,7 +185,7 @@ var renderFilterLists = function() {
|
||||
hasCachedContent = false;
|
||||
|
||||
// Visually split the filter lists in purpose-based groups
|
||||
var ulLists = uDom('#lists').empty();
|
||||
var ulLists = uDom('#lists').empty(), liGroup;
|
||||
var groups = groupsFromLists(details.available);
|
||||
var groupKey, i;
|
||||
var groupKeys = [
|
||||
@ -200,7 +200,12 @@ var renderFilterLists = function() {
|
||||
];
|
||||
for ( i = 0; i < groupKeys.length; i++ ) {
|
||||
groupKey = groupKeys[i];
|
||||
ulLists.append(liFromListGroup(groupKey, groups[groupKey]));
|
||||
liGroup = liFromListGroup(groupKey, groups[groupKey]);
|
||||
liGroup.toggleClass(
|
||||
'collapsed',
|
||||
vAPI.localStorage.getItem('collapseGroup' + (i + 1)) === 'y'
|
||||
);
|
||||
ulLists.append(liGroup);
|
||||
delete groups[groupKey];
|
||||
}
|
||||
// For all groups not covered above (if any left)
|
||||
@ -485,6 +490,19 @@ var externalListsApplyHandler = function() {
|
||||
|
||||
/******************************************************************************/
|
||||
|
||||
var groupEntryClickHandler = function() {
|
||||
var li = uDom(this).ancestors('.groupEntry');
|
||||
li.toggleClass('collapsed');
|
||||
var key = 'collapseGroup' + li.nthOfType();
|
||||
if ( li.hasClass('collapsed') ) {
|
||||
vAPI.localStorage.setItem(key, 'y');
|
||||
} else {
|
||||
vAPI.localStorage.removeItem(key);
|
||||
}
|
||||
};
|
||||
|
||||
/******************************************************************************/
|
||||
|
||||
uDom.onLoad(function() {
|
||||
uDom('#autoUpdate').on('change', autoUpdateCheckboxChanged);
|
||||
uDom('#parseCosmeticFilters').on('change', cosmeticSwitchChanged);
|
||||
@ -496,6 +514,7 @@ uDom.onLoad(function() {
|
||||
uDom('#lists').on('click', 'span.purge', onPurgeClicked);
|
||||
uDom('#externalLists').on('input', externalListsChangeHandler);
|
||||
uDom('#externalListsApply').on('click', externalListsApplyHandler);
|
||||
uDom('#lists').on('click', '.groupEntry > span', groupEntryClickHandler);
|
||||
|
||||
renderFilterLists();
|
||||
renderExternalLists();
|
||||
|
@ -19,6 +19,7 @@
|
||||
Home: https://github.com/gorhill/uBlock
|
||||
*/
|
||||
|
||||
/* global DOMTokenList */
|
||||
/* exported uDom */
|
||||
|
||||
/******************************************************************************/
|
||||
@ -488,6 +489,28 @@ DOMList.prototype.clone = function(notDeep) {
|
||||
|
||||
/******************************************************************************/
|
||||
|
||||
DOMList.prototype.nthOfType = function() {
|
||||
if ( this.nodes.length === 0 ) {
|
||||
return 0;
|
||||
}
|
||||
var node = this.nodes[0];
|
||||
var tagName = node.tagName;
|
||||
var i = 1;
|
||||
while ( node.previousElementSibling !== null ) {
|
||||
node = node.previousElementSibling;
|
||||
if ( typeof node.tagName !== 'string' ) {
|
||||
continue;
|
||||
}
|
||||
if ( node.tagName !== tagName ) {
|
||||
continue;
|
||||
}
|
||||
i++;
|
||||
}
|
||||
return i;
|
||||
};
|
||||
|
||||
/******************************************************************************/
|
||||
|
||||
DOMList.prototype.attr = function(attr, value) {
|
||||
var i = this.nodes.length;
|
||||
if ( value === undefined && typeof attr !== 'object' ) {
|
||||
|
Loading…
Reference in New Issue
Block a user