'use strict'; exports.type = 'perItem'; exports.active = false; exports.description = 'removes arbitrary elements by ID or className (disabled by default)'; exports.params = { id: [], class: [] }; /** * Remove arbitrary SVG elements by ID or className. * * @param id * examples: * * > single: remove element with ID of `elementID` * --- * removeElementsByAttr: * id: 'elementID' * * > list: remove multiple elements by ID * --- * removeElementsByAttr: * id: * - 'elementID' * - 'anotherID' * * @param class * examples: * * > single: remove all elements with class of `elementClass` * --- * removeElementsByAttr: * class: 'elementClass' * * > list: remove all elements with class of `elementClass` or `anotherClass` * --- * removeElementsByAttr: * class: * - 'elementClass' * - 'anotherClass' * * @param {Object} item current iteration item * @param {Object} params plugin params * @return {Boolean} if false, item will be filtered out * * @author Eli Dupuis (@elidupuis) */ exports.fn = function(item, params) { var elemId, elemClass; // wrap params in an array if not already ['id', 'class'].forEach(function(key) { if (!Array.isArray(params[key])) { params[key] = [ params[key] ]; } }); // abort if current item is no an element if (!item.isElem()) { return; } // remove element if it's `id` matches configured `id` params elemId = item.attr('id'); if (elemId) { return params.id.indexOf(elemId.value) === -1; } // remove element if it's `class` contains any of the configured `class` params elemClass = item.attr('class'); if (elemClass) { var hasClassRegex = new RegExp(params.class.join('|')); return !hasClassRegex.test(elemClass.value); } };