#!/usr/bin/env node /** * 将思维导图的md格式转化为html,提供在线预览 * 链接:https://www.npmjs.com/package/markmap-cli */ const {execShell} = require("./.exec"); const path = require('path'); const fs = require('fs'); const markMapSourcePath = path.join(__dirname, '../', 'docs/manuscripts/mark-map') const markMapTargetPath = path.join(__dirname, '../', 'docs/.vuepress/public/mark-map') /** * 扫面目录 */ function scanDirectory(directory, fileType) { const fileList = fs.readdirSync(directory) return fileList .map(file => { const filePath = path.join(directory, file); const fileExtension = path.extname(file).toLowerCase(); if (fileExtension === `.${fileType.toLowerCase()}`) { return filePath } }) // 过滤空 .filter(c => c != null) } (async () => { /** * 第一步: 清空站点思维导图文件存放目录 */ const delHtmlDir = `rm -rf ${path.join(markMapTargetPath, '*')}` /** * 第二步: 将md文档转化为思维导图网页 */ const mdList = scanDirectory(markMapSourcePath, 'md') const mdToHtmlCmdStr = mdList.map(md => `markmap --no-open ${md}`).join(' && ') /** * 第三步: 根据文件类型将思维导图网页文件移动到站点指定目录 * */ const mdHtmlByFileType = path.join(markMapSourcePath, '*.html') const moveHtmlCmdStr = `mv -f ${mdHtmlByFileType} ${markMapTargetPath}` /** * 第四步: 将xmind思维导图原件复制到指定目录 * */ const xmindByFileType = path.join(markMapSourcePath, '*.xmind') const cpXmindCmdStr = `cp -f ${xmindByFileType} ${markMapTargetPath}` /** * 第五步: 复制mark-map对应的json文件 */ const cpIndexJsonCmdStr = `cp -f ${path.join(markMapSourcePath, 'index.json')} ${markMapTargetPath}` // 脚本执行 await execShell([ delHtmlDir, mdToHtmlCmdStr, moveHtmlCmdStr, cpXmindCmdStr, cpIndexJsonCmdStr ]) /** * 第六步: 对mark-map中的xmind文件重命名 * */ const markMapData = require(path.join(markMapTargetPath, 'index.json')) for (const {originXmindFileName, targetXmindFileName} of markMapData) { const originPath = path.join(markMapTargetPath, originXmindFileName) const targetPath = path.join(markMapTargetPath, targetXmindFileName) await fs.renameSync(originPath, targetPath) } })()