✅ 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.
52 lines
1.1 KiB
JavaScript
52 lines
1.1 KiB
JavaScript
import { LeftCurlyBracket } from '../../tokenizer/index.js';
|
|
|
|
function consumeRaw() {
|
|
return this.Raw(this.consumeUntilLeftCurlyBracket, true);
|
|
}
|
|
|
|
function consumePrelude() {
|
|
const prelude = this.SelectorList();
|
|
|
|
if (prelude.type !== 'Raw' &&
|
|
this.eof === false &&
|
|
this.tokenType !== LeftCurlyBracket) {
|
|
this.error();
|
|
}
|
|
|
|
return prelude;
|
|
}
|
|
|
|
export const name = 'Rule';
|
|
export const walkContext = 'rule';
|
|
export const structure = {
|
|
prelude: ['SelectorList', 'Raw'],
|
|
block: ['Block']
|
|
};
|
|
|
|
export function parse() {
|
|
const startToken = this.tokenIndex;
|
|
const startOffset = this.tokenStart;
|
|
let prelude;
|
|
let block;
|
|
|
|
if (this.parseRulePrelude) {
|
|
prelude = this.parseWithFallback(consumePrelude, consumeRaw);
|
|
} else {
|
|
prelude = consumeRaw.call(this, startToken);
|
|
}
|
|
|
|
block = this.Block(true);
|
|
|
|
return {
|
|
type: 'Rule',
|
|
loc: this.getLocation(startOffset, this.tokenStart),
|
|
prelude,
|
|
block
|
|
};
|
|
}
|
|
export function generate(node) {
|
|
this.node(node.prelude);
|
|
this.node(node.block);
|
|
}
|
|
|