38 lines
1.2 KiB
TypeScript
38 lines
1.2 KiB
TypeScript
// src/plugins/updatePackageJson.ts
|
|
import type { Plugin } from 'vite'
|
|
import fs from 'node:fs/promises'
|
|
import path from 'node:path'
|
|
import process from 'node:process'
|
|
|
|
function updatePackageJson(): Plugin {
|
|
return {
|
|
name: 'update-package-json',
|
|
async buildStart() {
|
|
// 只在生产环境构建时执行
|
|
if (process.env.NODE_ENV !== 'production')
|
|
return
|
|
|
|
const packageJsonPath = path.resolve(process.cwd(), 'package.json')
|
|
|
|
try {
|
|
// 读取并解析 package.json
|
|
const content = await fs.readFile(packageJsonPath, 'utf-8')
|
|
const packageJson = JSON.parse(content)
|
|
|
|
// 更新时间戳(使用 ISO 格式或自定义格式)
|
|
packageJson['update-time'] = new Date().toISOString().split('T')[0] // YYYY-MM-DD
|
|
|
|
// 写回文件(保持 2 空格缩进)
|
|
await fs.writeFile(packageJsonPath, `${JSON.stringify(packageJson, null, 2)}\n`, 'utf-8')
|
|
|
|
console.log(`[update-package-json] 更新时间戳: ${packageJson['update-time']}`)
|
|
}
|
|
catch (error) {
|
|
console.error('[update-package-json] 插件执行失败:', error)
|
|
}
|
|
},
|
|
}
|
|
}
|
|
|
|
export default updatePackageJson
|