'use strict'; const { querySelectorAll } = require('../lib/xast.js'); exports.name = 'removeAttributesBySelector'; exports.type = 'visitor'; exports.active = false; exports.description = 'removes attributes of elements that match a css selector'; /** * Removes attributes of elements that match a css selector. * * @example * A selector removing a single attribute * plugins: [ * { * name: "removeAttributesBySelector", * params: { * selector: "[fill='#00ff00']" * attributes: "fill" * } * } * ] * * * ↓ * * * A selector removing multiple attributes * plugins: [ * { * name: "removeAttributesBySelector", * params: { * selector: "[fill='#00ff00']", * attributes: [ * "fill", * "stroke" * ] * } * } * ] * * * ↓ * * * Multiple selectors removing attributes * plugins: [ * { * name: "removeAttributesBySelector", * params: { * selectors: [ * { * selector: "[fill='#00ff00']", * attributes: "fill" * }, * { * selector: "#remove", * attributes: [ * "stroke", * "id" * ] * } * ] * } * } * ] * * * ↓ * * * @link https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_Selectors|MDN CSS Selectors * * @author Bradley Mease * * @type {import('../lib/types').Plugin} */ exports.fn = (root, params) => { const selectors = Array.isArray(params.selectors) ? params.selectors : [params]; for (const { selector, attributes } of selectors) { const nodes = querySelectorAll(root, selector); for (const node of nodes) { if (node.type === 'element') { if (Array.isArray(attributes)) { for (const name of attributes) { delete node.attributes[name]; } } else { delete node.attributes[attributes]; } } } } return {}; };