2023-05-30 16:02:20 +01:00
|
|
|
import path from 'path'
|
2023-06-02 00:48:38 +01:00
|
|
|
import SlugAnchor from 'github-slugger'
|
|
|
|
|
|
|
|
const slugAnchor = new SlugAnchor()
|
2023-05-30 16:02:20 +01:00
|
|
|
|
2023-05-31 22:01:23 +01:00
|
|
|
function slugSegment(s: string): string {
|
|
|
|
return s.replace(/\s/g, '-')
|
|
|
|
}
|
|
|
|
|
|
|
|
export function slugify(s: string): string {
|
|
|
|
const [fp, anchor] = s.split("#", 2)
|
2023-06-02 00:48:38 +01:00
|
|
|
const sluggedAnchor = anchor === undefined ? "" : "#" + slugAnchor.slug(anchor)
|
2023-05-31 22:01:23 +01:00
|
|
|
const withoutFileExt = fp.replace(new RegExp(path.extname(fp) + '$'), '')
|
|
|
|
const rawSlugSegments = withoutFileExt.split(path.sep)
|
|
|
|
const slugParts: string = rawSlugSegments
|
|
|
|
.map((segment) => slugSegment(segment))
|
|
|
|
.join(path.posix.sep)
|
|
|
|
.replace(/\/$/, '')
|
|
|
|
return path.normalize(slugParts) + sluggedAnchor
|
2023-05-30 16:02:20 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
// resolve /a/b/c to ../../
|
|
|
|
export function resolveToRoot(slug: string): string {
|
|
|
|
let fp = slug
|
2023-06-03 20:07:19 +01:00
|
|
|
if (fp.endsWith("index")) {
|
|
|
|
fp = fp.slice(0, -"index".length)
|
2023-05-30 16:02:20 +01:00
|
|
|
}
|
|
|
|
|
2023-06-03 20:07:19 +01:00
|
|
|
if (fp === "") {
|
|
|
|
return "."
|
|
|
|
}
|
|
|
|
|
|
|
|
return "./" + fp
|
2023-05-31 22:01:23 +01:00
|
|
|
.split('/')
|
|
|
|
.filter(x => x !== '')
|
|
|
|
.map(_ => '..')
|
|
|
|
.join('/')
|
|
|
|
}
|
|
|
|
|
|
|
|
export function relativeToRoot(slug: string, fp: string): string {
|
|
|
|
return path.join(resolveToRoot(slug), fp)
|
2023-05-30 16:02:20 +01:00
|
|
|
}
|
2023-05-31 22:01:23 +01:00
|
|
|
|
|
|
|
export function relative(src: string, dest: string): string {
|
|
|
|
return path.relative(src, dest)
|
|
|
|
}
|
|
|
|
|
|
|
|
export const QUARTZ = "quartz"
|