✅ 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.
21 lines
727 B
JavaScript
21 lines
727 B
JavaScript
'use strict';
|
|
/**
|
|
* Determine what entries should be displayed on the screen, based on the
|
|
* currently selected index and the maximum visible. Used in list-based
|
|
* prompts like `select` and `multiselect`.
|
|
*
|
|
* @param {number} cursor the currently selected entry
|
|
* @param {number} total the total entries available to display
|
|
* @param {number} [maxVisible] the number of entries that can be displayed
|
|
*/
|
|
|
|
module.exports = (cursor, total, maxVisible) => {
|
|
maxVisible = maxVisible || total;
|
|
let startIndex = Math.min(total - maxVisible, cursor - Math.floor(maxVisible / 2));
|
|
if (startIndex < 0) startIndex = 0;
|
|
let endIndex = Math.min(startIndex + maxVisible, total);
|
|
return {
|
|
startIndex,
|
|
endIndex
|
|
};
|
|
}; |