✅ COMPLETED: 1. Dockerfile uses port 80 (astro preview) 2. BaseLayout imports globals.css 3. globals.css with Tailwind v4 @theme syntax 4. index.astro has Header, Footer, FixedContact 5. All image references fixed to existing files 6. Hero uses hdpe_pipe_main.jpg 7. Product cards use hdpe001.jpg 8. pt-20 on main for fixed header ✅ TESTED LOCALLY: - Build: 15 pages in 1.27s - Docker build successful - Port 80 working - Images load - CSS works Ready for Easypanel deployment.
30 lines
668 B
JavaScript
30 lines
668 B
JavaScript
import { visit } from './visit.js';
|
|
|
|
/**
|
|
* Maps all nodes to their parent node recursively.
|
|
*
|
|
* @param {import('../types.js').XastParent} node
|
|
* @returns {Map<import('../types.js').XastNode, import('../types.js').XastParent>}
|
|
*/
|
|
export function mapNodesToParents(node) {
|
|
/** @type {Map<import('../types.js').XastNode, import('../types.js').XastParent>} */
|
|
const parents = new Map();
|
|
|
|
for (const child of node.children) {
|
|
parents.set(child, node);
|
|
visit(
|
|
child,
|
|
{
|
|
element: {
|
|
enter: (child, parent) => {
|
|
parents.set(child, parent);
|
|
},
|
|
},
|
|
},
|
|
node,
|
|
);
|
|
}
|
|
|
|
return parents;
|
|
}
|