2023-05-30 22:02:20 +07:00
|
|
|
import path from 'path'
|
2023-06-13 12:41:42 +07:00
|
|
|
import { slug as slugAnchor } from 'github-slugger'
|
2023-05-30 22:02:20 +07:00
|
|
|
|
2023-06-01 04:01:23 +07: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-13 12:41:42 +07:00
|
|
|
const sluggedAnchor = anchor === undefined ? "" : "#" + slugAnchor(anchor)
|
2023-06-01 04:01:23 +07: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 22:02:20 +07:00
|
|
|
}
|
|
|
|
|
|
|
|
// resolve /a/b/c to ../../
|
|
|
|
export function resolveToRoot(slug: string): string {
|
|
|
|
let fp = slug
|
2023-06-04 02:07:19 +07:00
|
|
|
if (fp.endsWith("index")) {
|
|
|
|
fp = fp.slice(0, -"index".length)
|
2023-05-30 22:02:20 +07:00
|
|
|
}
|
|
|
|
|
2023-06-04 02:07:19 +07:00
|
|
|
if (fp === "") {
|
|
|
|
return "."
|
|
|
|
}
|
|
|
|
|
|
|
|
return "./" + fp
|
2023-06-01 04:01:23 +07:00
|
|
|
.split('/')
|
|
|
|
.filter(x => x !== '')
|
|
|
|
.map(_ => '..')
|
|
|
|
.join('/')
|
|
|
|
}
|
|
|
|
|
|
|
|
export function relativeToRoot(slug: string, fp: string): string {
|
|
|
|
return path.join(resolveToRoot(slug), fp)
|
2023-05-30 22:02:20 +07:00
|
|
|
}
|
2023-06-01 04:01:23 +07:00
|
|
|
|
|
|
|
export function relative(src: string, dest: string): string {
|
|
|
|
return path.relative(src, dest)
|
|
|
|
}
|
|
|
|
|
|
|
|
export const QUARTZ = "quartz"
|