✅ 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.
37 lines
1.0 KiB
TypeScript
37 lines
1.0 KiB
TypeScript
import type {
|
|
CodeKeywordDefinition,
|
|
KeywordErrorDefinition,
|
|
ErrorObject,
|
|
AnySchema,
|
|
} from "../../types"
|
|
import type {KeywordCxt} from "../../compile/validate"
|
|
import {_, str} from "../../compile/codegen"
|
|
import {alwaysValidSchema} from "../../compile/util"
|
|
import {validateArray} from "../code"
|
|
import {validateAdditionalItems} from "./additionalItems"
|
|
|
|
export type ItemsError = ErrorObject<"items", {limit: number}, AnySchema>
|
|
|
|
const error: KeywordErrorDefinition = {
|
|
message: ({params: {len}}) => str`must NOT have more than ${len} items`,
|
|
params: ({params: {len}}) => _`{limit: ${len}}`,
|
|
}
|
|
|
|
const def: CodeKeywordDefinition = {
|
|
keyword: "items",
|
|
type: "array",
|
|
schemaType: ["object", "boolean"],
|
|
before: "uniqueItems",
|
|
error,
|
|
code(cxt: KeywordCxt) {
|
|
const {schema, parentSchema, it} = cxt
|
|
const {prefixItems} = parentSchema
|
|
it.items = true
|
|
if (alwaysValidSchema(it, schema)) return
|
|
if (prefixItems) validateAdditionalItems(cxt, prefixItems)
|
|
else cxt.ok(validateArray(cxt))
|
|
},
|
|
}
|
|
|
|
export default def
|