Files
dealplustech/node_modules/svgo/lib/xast.js
Kunthawat Greethong 6562a1748f fix: Fix product page syntax errors
1. Remove duplicate/broken code in product tables section
2. Fix PostCSS config for Tailwind 4
3. Add @tailwindcss/postcss dependency
4. Remove --production flag from Dockerfile (sharp required)

All fixes enable successful Docker build with favicon working.
2026-03-03 14:57:46 +07:00

54 lines
2.0 KiB
JavaScript

import { is, selectAll, selectOne } from 'css-select';
import { createAdapter } from './svgo/css-select-adapter.js';
/**
* @param {import('./types.js').XastParent} relativeNode
* @param {Map<import('./types.js').XastNode, import('./types.js').XastParent>=} parents
* @returns {import('css-select').Options<import('./types.js').XastNode & { children?: any }, import('./types.js').XastElement>}
*/
function createCssSelectOptions(relativeNode, parents) {
return {
xmlMode: true,
adapter: createAdapter(relativeNode, parents),
};
}
/**
* @param {import('./types.js').XastParent} node Element to query the children of.
* @param {string} selector CSS selector string.
* @param {Map<import('./types.js').XastNode, import('./types.js').XastParent>=} parents
* @returns {import('./types.js').XastChild[]} All matching elements.
*/
export const querySelectorAll = (node, selector, parents) => {
return selectAll(selector, node, createCssSelectOptions(node, parents));
};
/**
* @param {import('./types.js').XastParent} node Element to query the children of.
* @param {string} selector CSS selector string.
* @param {Map<import('./types.js').XastNode, import('./types.js').XastParent>=} parents
* @returns {?import('./types.js').XastChild} First match, or null if there was no match.
*/
export const querySelector = (node, selector, parents) => {
return selectOne(selector, node, createCssSelectOptions(node, parents));
};
/**
* @param {import('./types.js').XastElement} node
* @param {string} selector
* @param {Map<import('./types.js').XastNode, import('./types.js').XastParent>=} parents
* @returns {boolean}
*/
export const matches = (node, selector, parents) => {
return is(node, selector, createCssSelectOptions(node, parents));
};
/**
* @param {import('./types.js').XastChild} node
* @param {import('./types.js').XastParent} parentNode
*/
export const detachNodeFromParent = (node, parentNode) => {
// avoid splice to not break for loops
parentNode.children = parentNode.children.filter((child) => child !== node);
};