✅ 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.
31 lines
1.0 KiB
TypeScript
31 lines
1.0 KiB
TypeScript
import type {CodeKeywordDefinition, KeywordErrorDefinition} from "../../types"
|
|
import type {KeywordCxt} from "../../compile/validate"
|
|
import {_, str, operators} from "../../compile/codegen"
|
|
import {useFunc} from "../../compile/util"
|
|
import ucs2length from "../../runtime/ucs2length"
|
|
|
|
const error: KeywordErrorDefinition = {
|
|
message({keyword, schemaCode}) {
|
|
const comp = keyword === "maxLength" ? "more" : "fewer"
|
|
return str`must NOT have ${comp} than ${schemaCode} characters`
|
|
},
|
|
params: ({schemaCode}) => _`{limit: ${schemaCode}}`,
|
|
}
|
|
|
|
const def: CodeKeywordDefinition = {
|
|
keyword: ["maxLength", "minLength"],
|
|
type: "string",
|
|
schemaType: "number",
|
|
$data: true,
|
|
error,
|
|
code(cxt: KeywordCxt) {
|
|
const {keyword, data, schemaCode, it} = cxt
|
|
const op = keyword === "maxLength" ? operators.GT : operators.LT
|
|
const len =
|
|
it.opts.unicode === false ? _`${data}.length` : _`${useFunc(cxt.gen, ucs2length)}(${data})`
|
|
cxt.fail$data(_`${len} ${op} ${schemaCode}`)
|
|
},
|
|
}
|
|
|
|
export default def
|