✅ 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.
14 lines
780 B
TypeScript
14 lines
780 B
TypeScript
export type Value = Obj | Array<Value> | string | number | true | false | null;
|
|
export type Obj = {
|
|
[key: string]: Value | undefined;
|
|
};
|
|
export type ObjectFun<T> = (obj: Obj) => T;
|
|
export declare function string(value: Value | undefined): string;
|
|
export declare function stringOpt(value: Value | undefined): string | undefined;
|
|
export declare function number(value: Value | undefined): number;
|
|
export declare function boolean(value: Value | undefined): boolean;
|
|
export declare function array(value: Value | undefined): Array<Value>;
|
|
export declare function object(value: Value | undefined): Obj;
|
|
export declare function arrayObjectsMap<T>(value: Value | undefined, fun: ObjectFun<T>): Array<T>;
|
|
export declare function readJsonObject<T>(value: unknown, fun: ObjectFun<T>): T;
|