tgweb
Version:
Teamgenik Website Builder Offline Tool
116 lines (93 loc) • 4.47 kB
JavaScript
import * as PATH from "path"
import { slash } from "../utils/slash.mjs"
import fs from "fs"
import { updateSiteData } from "./update_site_data.mjs"
import { renderWebPage } from "./render_web_page.mjs"
import getType from "./get_type.mjs"
import { updateHTML } from "./update_html.mjs"
import { setDependencies } from "./set_dependencies.mjs"
import { generateTailwindConfig } from "./generate_tailwind_config.mjs"
import render from "dom-serializer"
import pretty from "pretty"
import { protectedFiles } from "./protected_files.mjs"
const create = (path, siteData) => {
const posixPath = slash(path)
if (protectedFiles.includes(posixPath.replace(/^src\//, ""))) return
const type = getType(posixPath)
const dirname = PATH.dirname(posixPath)
if (dirname.startsWith("src/images") || dirname.startsWith("src/animations") ||
dirname.startsWith("src/audios") || dirname.startsWith("src/css") ||
dirname.startsWith("src/js")) {
const distPath = posixPath.replace(/^src\//, "dist/")
const targetPath = PATH.resolve(distPath)
const targetDir = PATH.dirname(targetPath)
if (!fs.existsSync(targetDir)) fs.mkdirSync(targetDir, { recursive: true })
fs.copyFileSync(posixPath, targetPath)
}
else if (dirname.startsWith("src/icons")) {
const distPath = posixPath.replace(/^src\/icons\//, "dist/")
const targetPath = PATH.resolve(distPath)
const targetDir = PATH.dirname(targetPath)
if (!fs.existsSync(targetDir)) fs.mkdirSync(targetDir, { recursive: true })
fs.copyFileSync(posixPath, targetPath)
}
else if (dirname.startsWith("src/shared_css") || dirname.startsWith("src/shared_js")) {
const assetPath = posixPath.replace(/^src\/shared_/, "src/")
if (fs.existsSync(assetPath)) return
const distPath = assetPath.replace(/^src\//, "dist/")
const targetPath = PATH.resolve(distPath)
const targetDir = PATH.dirname(targetPath)
if (!fs.existsSync(targetDir)) fs.mkdirSync(targetDir, { recursive: true })
fs.copyFileSync(posixPath, targetPath)
}
else {
updateSiteData(siteData, posixPath)
if (type === "site.toml") {
siteData.pages.forEach(page => updateHTML(`src/${page.path}`, siteData))
siteData.articles.forEach(article => updateHTML(`src/${article.path}`, siteData))
return
}
else if (type === "color_scheme.toml") {
const tailwindConfig = generateTailwindConfig(PATH.dirname(posixPath))
if (tailwindConfig) fs.writeFileSync("tailwind.config.js", tailwindConfig)
if (process.env.VERBOSE) console.log(`Updated tailwind.config.js`)
return
}
else if (type === "page") {
const page = siteData.pages.find(page => "src/" + page.path === posixPath)
if (siteData.options["buildDrafts"] !== true && page.frontMatter.main &&
page.frontMatter.main["draft"] === true) return
const dom = renderWebPage(posixPath, siteData)
createHTML(posixPath, dom)
return
}
else if (type === "article") {
const article = siteData.articles.find(article => "src/" + article.path === posixPath)
if (siteData.options["buildDrafts"] !== true && article.frontMatter.main &&
article.frontMatter.main["draft"] === true) return
const dom = renderWebPage(posixPath, siteData)
if (dom !== undefined) createHTML(posixPath, dom)
}
const name = posixPath.replace(/^src\//, "").replace(/\.(html|toml)$/, "")
siteData.segments.forEach(s => setDependencies(s, siteData))
siteData.articles.forEach(a => setDependencies(a, siteData))
siteData.pages.forEach(p => setDependencies(p, siteData))
siteData.articles
.filter(article => article.dependencies.includes(name))
.forEach(article => updateHTML("src/" + article.path, siteData))
siteData.pages
.filter(page => page.dependencies.includes(name))
.forEach(page => updateHTML("src/" + page.path, siteData))
}
}
const createHTML = (posixPath, dom) => {
const html = pretty(render(dom, {encodeEntities: false}), {ocd: true})
const distPath = posixPath.replace(/^src\//, "dist/").replace(/^dist\/pages\//, "dist/")
const targetPath = PATH.resolve(distPath)
const targetDir = PATH.dirname(targetPath)
if (!fs.existsSync(targetDir)) fs.mkdirSync(targetDir, { recursive: true })
fs.writeFileSync(targetPath, "<!DOCTYPE html>\n")
fs.appendFileSync(targetPath, html)
if (process.env.VERBOSE) console.log(`Created ${distPath}.`)
}
export { create }