1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73
|
/*
* This file is part of Adblock Plus <http://adblockplus.org/>,
* Copyright (C) 2006-2014 Eyeo GmbH
*
* Adblock Plus is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License version 3 as
* published by the Free Software Foundation.
*
* Adblock Plus 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 Adblock Plus. If not, see <http://www.gnu.org/licenses/>.
*/
/**
* @fileOverview This component manages listeners and calls them to distributes
* messages about filter changes.
*/
/**
* List of registered listeners
* @type Array of function(action, item, newValue, oldValue)
*/
let listeners = [];
/**
* This class allows registering and triggering listeners for filter events.
* @class
*/
let FilterNotifier = exports.FilterNotifier =
{
/**
* Adds a listener
*/
addListener: function(/**function(action, item, newValue, oldValue)*/ listener)
{
if (listeners.indexOf(listener) >= 0)
return;
listeners.push(listener);
},
/**
* Removes a listener that was previosly added via addListener
*/
removeListener: function(/**function(action, item, newValue, oldValue)*/ listener)
{
let index = listeners.indexOf(listener);
if (index >= 0)
listeners.splice(index, 1);
},
/**
* Notifies listeners about an event
* @param {String} action event code ("load", "save", "elemhideupdate",
* "subscription.added", "subscription.removed",
* "subscription.disabled", "subscription.title",
* "subscription.lastDownload", "subscription.downloadStatus",
* "subscription.homepage", "subscription.updated",
* "filter.added", "filter.removed", "filter.moved",
* "filter.disabled", "filter.hitCount", "filter.lastHit")
* @param {Subscription|Filter} item item that the change applies to
*/
triggerListeners: function(action, item, param1, param2, param3)
{
let list = listeners.slice();
for (let listener of list)
listener(action, item, param1, param2, param3);
}
};
|