✅ 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.
38 lines
1.0 KiB
JavaScript
38 lines
1.0 KiB
JavaScript
import { Column } from "../../column.js";
|
|
import { is } from "../../entity.js";
|
|
import { sql } from "../sql.js";
|
|
function count(expression) {
|
|
return sql`count(${expression || sql.raw("*")})`.mapWith(Number);
|
|
}
|
|
function countDistinct(expression) {
|
|
return sql`count(distinct ${expression})`.mapWith(Number);
|
|
}
|
|
function avg(expression) {
|
|
return sql`avg(${expression})`.mapWith(String);
|
|
}
|
|
function avgDistinct(expression) {
|
|
return sql`avg(distinct ${expression})`.mapWith(String);
|
|
}
|
|
function sum(expression) {
|
|
return sql`sum(${expression})`.mapWith(String);
|
|
}
|
|
function sumDistinct(expression) {
|
|
return sql`sum(distinct ${expression})`.mapWith(String);
|
|
}
|
|
function max(expression) {
|
|
return sql`max(${expression})`.mapWith(is(expression, Column) ? expression : String);
|
|
}
|
|
function min(expression) {
|
|
return sql`min(${expression})`.mapWith(is(expression, Column) ? expression : String);
|
|
}
|
|
export {
|
|
avg,
|
|
avgDistinct,
|
|
count,
|
|
countDistinct,
|
|
max,
|
|
min,
|
|
sum,
|
|
sumDistinct
|
|
};
|
|
//# sourceMappingURL=aggregate.js.map
|