that.visitTargets = function(callback) {
for (var i in m_list) {
var filter = m_list[i];
- if (filter.id) {
+ if (filter.type === 'target') {
callback(filter.id, filter.name);
}
}
that.visitFields = function(callback) {
for (var i in m_list) {
var filter = m_list[i];
- if (!filter.id) {
+ if (filter.type === 'field') {
callback(filter.field, filter.value);
}
}
};
+ that.visitCategories = function(callback) {
+ for (var i in m_list) {
+ var filter = m_list[i];
+ if (filter.type === 'category') {
+ callback(filter.id);
+ }
+ }
+ };
+
that.removeMatching = function(matchFn) {
var newList = [];
for (var i in m_list) {
that.targetFiltered = function(id) {
for (var i = 0; i < m_list.length; i++) {
- if (m_list[i].id === id ||
+ if (m_list[i].type === 'target' ||
m_list[i].id === 'pz:id=' + id) {
return true;
}
};
that.pp2filter = function() {
- var OLD = that.OLD_pp2filter();
- var NEW = that.NEW_pp2filter();
- if (OLD !== NEW) {
- alert("pp2filter(): OLD[" + OLD + "] !== NEW[" + NEW + "]");
- }
- return OLD;
- };
-
- that.OLD_pp2filter = function() {
- var res = "";
-
- for (var i in m_list) {
- var filter = m_list[i];
- if (filter.id) {
- if (res) res += ",";
- if (filter.id.match(/^[a-z:]+[=~]/)) {
- m_team.log("filter '" + filter.id + "' already begins with SETTING OP");
- } else {
- filter.id = 'pz:id=' + filter.id;
- }
- res += filter.id;
- }
- }
-
- return res;
- };
-
- that.NEW_pp2filter = function() {
var res = "";
that.visitTargets(function(id, name) {
that.pp2limit = function(initial) {
var res = initial || "";
- for (var i in m_list) {
- var filter = m_list[i];
- if (!filter.id) {
- if (res) res += ",";
- res += filter.field + "=" + filter.value.replace(/[\\|,]/g, '\\$&');
- }
- }
-
+ that.visitFields(function(field, value) {
+ if (res) res += ",";
+ res += field + "=" + value.replace(/[\\|,]/g, '\\$&');
+ });
return res;
- };
+ }
+
+ that.pp2catLimit = function() {
+ var res = "";
+ that.visitCategories(function(id) {
+ if (res) res += ",";
+ res += "category~" + id.replace(/[\\|,]/g, '\\$&');
+ });
+ return res;
+ }
return that;
}
-// Factory function for filters. These can be of several types.
-function filter(id, name, field, value) {
- var res;
+// Factory functions for filters. These can be of several types.
+function targetFilter(id, name) {
+ return {
+ type: 'target',
+ id: id,
+ name: name
+ };
+}
- if (id) {
- res = { id: id, name: name };
- } else {
- res = { field: field, value: value };
- }
+function fieldFilter(field, value) {
+ return {
+ type: 'field',
+ field: field,
+ value: value
+ };
+}
- return res;
+function categoryFilter(id) {
+ return {
+ type: 'category',
+ id: id,
+ };
}