✅ 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.
35 lines
1.0 KiB
TypeScript
35 lines
1.0 KiB
TypeScript
import type {CodeKeywordDefinition, ErrorObject, KeywordErrorDefinition} from "../../types"
|
|
import type {KeywordCxt} from "../../compile/validate"
|
|
import {_, str} from "../../compile/codegen"
|
|
|
|
export type MultipleOfError = ErrorObject<
|
|
"multipleOf",
|
|
{multipleOf: number},
|
|
number | {$data: string}
|
|
>
|
|
|
|
const error: KeywordErrorDefinition = {
|
|
message: ({schemaCode}) => str`must be multiple of ${schemaCode}`,
|
|
params: ({schemaCode}) => _`{multipleOf: ${schemaCode}}`,
|
|
}
|
|
|
|
const def: CodeKeywordDefinition = {
|
|
keyword: "multipleOf",
|
|
type: "number",
|
|
schemaType: "number",
|
|
$data: true,
|
|
error,
|
|
code(cxt: KeywordCxt) {
|
|
const {gen, data, schemaCode, it} = cxt
|
|
// const bdt = bad$DataType(schemaCode, <string>def.schemaType, $data)
|
|
const prec = it.opts.multipleOfPrecision
|
|
const res = gen.let("res")
|
|
const invalid = prec
|
|
? _`Math.abs(Math.round(${res}) - ${res}) > 1e-${prec}`
|
|
: _`${res} !== parseInt(${res})`
|
|
cxt.fail$data(_`(${schemaCode} === 0 || (${res} = ${data}/${schemaCode}, ${invalid}))`)
|
|
},
|
|
}
|
|
|
|
export default def
|