mirror of
https://github.com/dilllxd/gitfolio.git
synced 2024-08-14 22:28:09 +00:00
115 lines
No EOL
2.8 KiB
JavaScript
115 lines
No EOL
2.8 KiB
JavaScript
/* Filepath utilities */
|
|
const path = require("path");
|
|
/* Promise library */
|
|
const bluebird = require("bluebird");
|
|
const hbs = require("handlebars");
|
|
/* Creates promise-returning async functions
|
|
from callback-passed async functions */
|
|
const fs = bluebird.promisifyAll(require("fs"));
|
|
const
|
|
{
|
|
updateHTML
|
|
} = require("./populate");
|
|
const
|
|
{
|
|
getConfig,
|
|
outDir
|
|
} = require("./utils");
|
|
|
|
const assetDir = path.resolve(`${__dirname}/assets/`);
|
|
const config = path.join(outDir, "config.json");
|
|
|
|
/**
|
|
* Creates the stylesheet used by the site from a template stylesheet.
|
|
*
|
|
* Theme styles are added to the new stylesheet depending on command line
|
|
* arguments.
|
|
*/
|
|
async function populateCSS(
|
|
{
|
|
theme = "light",
|
|
background = "https://images.unsplash.com/photo-1553748024-d1b27fb3f960?w=1500&q=80"
|
|
} = {})
|
|
{
|
|
/* Get the theme the user requests. Defaults to 'light' */
|
|
theme = `${theme}.css`;
|
|
let template = path.resolve(assetDir, "index.css");
|
|
let stylesheet = path.join(outDir, "index.css");
|
|
|
|
try
|
|
{
|
|
await fs.accessAsync(outDir, fs.constants.F_OK);
|
|
}
|
|
catch (err)
|
|
{
|
|
await fs.mkdirAsync(outDir);
|
|
}
|
|
/* Copy over the template CSS stylesheet */
|
|
await fs.copyFileAsync(template, stylesheet);
|
|
|
|
/* Get an array of every available theme */
|
|
let themes = await fs.readdirAsync(path.join(assetDir, "themes"));
|
|
|
|
if (!themes.includes(theme))
|
|
{
|
|
console.error('Error: Requested theme not found. Defaulting to "light".');
|
|
theme = "light";
|
|
}
|
|
/* Read in the theme stylesheet */
|
|
let themeSource = await fs.readFileSync(path.join(assetDir, "themes", theme));
|
|
themeSource = themeSource.toString("utf-8");
|
|
let themeTemplate = hbs.compile(themeSource);
|
|
let styles = themeTemplate(
|
|
{
|
|
background: `${background}`
|
|
});
|
|
/* Add the user-specified styles to the new stylesheet */
|
|
await fs.appendFileAsync(stylesheet, styles);
|
|
|
|
/* Update the config file with the user's theme choice */
|
|
const data = await getConfig();
|
|
data[0].theme = theme;
|
|
await fs.writeFileAsync(config, JSON.stringify(data, null, " "));
|
|
}
|
|
|
|
async function populateConfig(opts)
|
|
{
|
|
const data = await getConfig();
|
|
Object.assign(data[0], opts);
|
|
await fs.writeFileAsync(config, JSON.stringify(data, null, " "));
|
|
}
|
|
|
|
async function buildCommand(username, program)
|
|
{
|
|
await populateCSS(program);
|
|
let types;
|
|
if (!program.include || !program.include.length)
|
|
{
|
|
types = ["all"];
|
|
}
|
|
else
|
|
{
|
|
types = program.include;
|
|
}
|
|
const opts = {
|
|
sort: program.sort,
|
|
order: program.order,
|
|
includeFork: program.fork ? true : false,
|
|
types,
|
|
codepen: program.codepen,
|
|
dev: program.dev,
|
|
dribbble: program.dribbble,
|
|
email: program.email,
|
|
instagram: program.instagram,
|
|
twitter: program.twitter
|
|
};
|
|
|
|
await populateConfig(opts);
|
|
updateHTML(("%s", username), opts);
|
|
}
|
|
|
|
module.exports = {
|
|
buildCommand,
|
|
populateCSS,
|
|
populateConfig
|
|
}; |