✅ 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.
47 lines
1.0 KiB
JavaScript
47 lines
1.0 KiB
JavaScript
/*
|
|
MIT License http://www.opensource.org/licenses/mit-license.php
|
|
Author Tobias Koppers @sokra
|
|
*/
|
|
"use strict";
|
|
|
|
const Hook = require("./Hook");
|
|
const HookCodeFactory = require("./HookCodeFactory");
|
|
|
|
class SyncLoopHookCodeFactory extends HookCodeFactory {
|
|
content({ onError, onDone, rethrowIfPossible }) {
|
|
return this.callTapsLooping({
|
|
onError: (i, err) => onError(err),
|
|
onDone,
|
|
rethrowIfPossible
|
|
});
|
|
}
|
|
}
|
|
|
|
const factory = new SyncLoopHookCodeFactory();
|
|
|
|
const TAP_ASYNC = () => {
|
|
throw new Error("tapAsync is not supported on a SyncLoopHook");
|
|
};
|
|
|
|
const TAP_PROMISE = () => {
|
|
throw new Error("tapPromise is not supported on a SyncLoopHook");
|
|
};
|
|
|
|
function COMPILE(options) {
|
|
factory.setup(this, options);
|
|
return factory.create(options);
|
|
}
|
|
|
|
function SyncLoopHook(args = [], name = undefined) {
|
|
const hook = new Hook(args, name);
|
|
hook.constructor = SyncLoopHook;
|
|
hook.tapAsync = TAP_ASYNC;
|
|
hook.tapPromise = TAP_PROMISE;
|
|
hook.compile = COMPILE;
|
|
return hook;
|
|
}
|
|
|
|
SyncLoopHook.prototype = null;
|
|
|
|
module.exports = SyncLoopHook;
|