✅ 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.
25 lines
716 B
TypeScript
25 lines
716 B
TypeScript
import {KeywordCxt} from "../../ajv"
|
|
import type {CodeKeywordDefinition} from "../../types"
|
|
import {alwaysValidSchema} from "../../compile/util"
|
|
|
|
const def: CodeKeywordDefinition = {
|
|
keyword: "metadata",
|
|
schemaType: "object",
|
|
code(cxt: KeywordCxt) {
|
|
checkMetadata(cxt)
|
|
const {gen, schema, it} = cxt
|
|
if (alwaysValidSchema(it, schema)) return
|
|
const valid = gen.name("valid")
|
|
cxt.subschema({keyword: "metadata", jtdMetadata: true}, valid)
|
|
cxt.ok(valid)
|
|
},
|
|
}
|
|
|
|
export function checkMetadata({it, keyword}: KeywordCxt, metadata?: boolean): void {
|
|
if (it.jtdMetadata !== metadata) {
|
|
throw new Error(`JTD: "${keyword}" cannot be used in this schema location`)
|
|
}
|
|
}
|
|
|
|
export default def
|