✅ 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.
78 lines
1.8 KiB
JavaScript
78 lines
1.8 KiB
JavaScript
import { regex } from './regex.js'
|
|
|
|
const own = Object.hasOwnProperty
|
|
|
|
/**
|
|
* Slugger.
|
|
*/
|
|
export default class BananaSlug {
|
|
/**
|
|
* Create a new slug class.
|
|
*/
|
|
constructor () {
|
|
/** @type {Record<string, number>} */
|
|
// eslint-disable-next-line no-unused-expressions
|
|
this.occurrences
|
|
|
|
this.reset()
|
|
}
|
|
|
|
/**
|
|
* Generate a unique slug.
|
|
*
|
|
* Tracks previously generated slugs: repeated calls with the same value
|
|
* will result in different slugs.
|
|
* Use the `slug` function to get same slugs.
|
|
*
|
|
* @param {string} value
|
|
* String of text to slugify
|
|
* @param {boolean} [maintainCase=false]
|
|
* Keep the current case, otherwise make all lowercase
|
|
* @return {string}
|
|
* A unique slug string
|
|
*/
|
|
slug (value, maintainCase) {
|
|
const self = this
|
|
let result = slug(value, maintainCase === true)
|
|
const originalSlug = result
|
|
|
|
while (own.call(self.occurrences, result)) {
|
|
self.occurrences[originalSlug]++
|
|
result = originalSlug + '-' + self.occurrences[originalSlug]
|
|
}
|
|
|
|
self.occurrences[result] = 0
|
|
|
|
return result
|
|
}
|
|
|
|
/**
|
|
* Reset - Forget all previous slugs
|
|
*
|
|
* @return void
|
|
*/
|
|
reset () {
|
|
this.occurrences = Object.create(null)
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Generate a slug.
|
|
*
|
|
* Does not track previously generated slugs: repeated calls with the same value
|
|
* will result in the exact same slug.
|
|
* Use the `GithubSlugger` class to get unique slugs.
|
|
*
|
|
* @param {string} value
|
|
* String of text to slugify
|
|
* @param {boolean} [maintainCase=false]
|
|
* Keep the current case, otherwise make all lowercase
|
|
* @return {string}
|
|
* A unique slug string
|
|
*/
|
|
export function slug (value, maintainCase) {
|
|
if (typeof value !== 'string') return ''
|
|
if (!maintainCase) value = value.toLowerCase()
|
|
return value.replace(regex, '').replace(/ /g, '-')
|
|
}
|