From 951d1dec24eb8e0bea4ec548cc79c5ce718bf02f Mon Sep 17 00:00:00 2001
From: fl0werpowers <47599466+fl0werpowers@users.noreply.github.com>
Date: Wed, 28 May 2025 08:40:51 +0000
Subject: [PATCH] chore(deps): replace `chalk` and `rimraf` with builtin functions (#1879)
---
quartz/plugins/transformers/lastmod.ts | 46 ++++++++++++++++++++++++++++------------------
1 files changed, 28 insertions(+), 18 deletions(-)
diff --git a/quartz/plugins/transformers/lastmod.ts b/quartz/plugins/transformers/lastmod.ts
index fd57692..668634a 100644
--- a/quartz/plugins/transformers/lastmod.ts
+++ b/quartz/plugins/transformers/lastmod.ts
@@ -1,8 +1,8 @@
import fs from "fs"
-import path from "path"
import { Repository } from "@napi-rs/simple-git"
import { QuartzTransformerPlugin } from "../types"
-import chalk from "chalk"
+import path from "path"
+import { styleText } from "util"
export interface Options {
priority: ("frontmatter" | "git" | "filesystem")[]
@@ -17,7 +17,8 @@
const invalidDate = isNaN(dt.getTime()) || dt.getTime() === 0
if (invalidDate && d !== undefined) {
console.log(
- chalk.yellow(
+ styleText(
+ "yellow",
`\nWarning: found invalid date "${d}" in \`${fp}\`. Supported formats: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Date#date_time_string_format`,
),
)
@@ -31,17 +32,32 @@
const opts = { ...defaultOptions, ...userOpts }
return {
name: "CreatedModifiedDate",
- markdownPlugins() {
+ markdownPlugins(ctx) {
return [
() => {
let repo: Repository | undefined = undefined
+ let repositoryWorkdir: string
+ if (opts.priority.includes("git")) {
+ try {
+ repo = Repository.discover(ctx.argv.directory)
+ repositoryWorkdir = repo.workdir() ?? ctx.argv.directory
+ } catch (e) {
+ console.log(
+ styleText(
+ "yellow",
+ `\nWarning: couldn't find git repository for ${ctx.argv.directory}`,
+ ),
+ )
+ }
+ }
+
return async (_tree, file) => {
let created: MaybeDate = undefined
let modified: MaybeDate = undefined
let published: MaybeDate = undefined
- const fp = file.data.filePath!
- const fullFp = path.isAbsolute(fp) ? fp : path.posix.join(file.cwd, fp)
+ const fp = file.data.relativePath!
+ const fullFp = file.data.filePath!
for (const source of opts.priority) {
if (source === "filesystem") {
const st = await fs.promises.stat(fullFp)
@@ -51,21 +67,15 @@
created ||= file.data.frontmatter.created as MaybeDate
modified ||= file.data.frontmatter.modified as MaybeDate
published ||= file.data.frontmatter.published as MaybeDate
- } else if (source === "git") {
- if (!repo) {
- // Get a reference to the main git repo.
- // It's either the same as the workdir,
- // or 1+ level higher in case of a submodule/subtree setup
- repo = Repository.discover(file.cwd)
- }
-
+ } else if (source === "git" && repo) {
try {
- modified ||= await repo.getFileLatestModifiedDateAsync(file.data.filePath!)
+ const relativePath = path.relative(repositoryWorkdir, fullFp)
+ modified ||= await repo.getFileLatestModifiedDateAsync(relativePath)
} catch {
console.log(
- chalk.yellow(
- `\nWarning: ${file.data
- .filePath!} isn't yet tracked by git, last modification date is not available for this file`,
+ styleText(
+ "yellow",
+ `\nWarning: ${file.data.filePath!} isn't yet tracked by git, dates will be inaccurate`,
),
)
}
--
Gitblit v1.10.0