forked from mirrors/catstodon
872a0d5bd8
* Use PNG images in HTML e-mails * Make webpack use URLs with host so fonts load inside HTML e-mails Convert this back to a relative URL in the premailer CSS loader since local requests are quicker * Improve responsive design * Add missing PNG icon
39 lines
1.1 KiB
JavaScript
39 lines
1.1 KiB
JavaScript
// Common configuration for webpacker loaded from config/webpacker.yml
|
|
|
|
const { join, resolve } = require('path');
|
|
const { env } = require('process');
|
|
const { safeLoad } = require('js-yaml');
|
|
const { readFileSync } = require('fs');
|
|
|
|
const configPath = resolve('config', 'webpacker.yml');
|
|
const loadersDir = join(__dirname, 'loaders');
|
|
const settings = safeLoad(readFileSync(configPath), 'utf8')[env.NODE_ENV];
|
|
|
|
const themePath = resolve('config', 'themes.yml');
|
|
const themes = safeLoad(readFileSync(themePath), 'utf8');
|
|
|
|
function removeOuterSlashes(string) {
|
|
return string.replace(/^\/*/, '').replace(/\/*$/, '');
|
|
}
|
|
|
|
function formatPublicPath(host = '', path = '') {
|
|
let formattedHost = removeOuterSlashes(host);
|
|
if (formattedHost && !/^http/i.test(formattedHost)) {
|
|
formattedHost = `//${formattedHost}`;
|
|
}
|
|
const formattedPath = removeOuterSlashes(path);
|
|
return `${formattedHost}/${formattedPath}/`;
|
|
}
|
|
|
|
const output = {
|
|
path: resolve('public', settings.public_output_path),
|
|
publicPath: formatPublicPath(env.ASSET_HOST || env.LOCAL_DOMAIN, settings.public_output_path),
|
|
};
|
|
|
|
module.exports = {
|
|
settings,
|
|
themes,
|
|
env,
|
|
loadersDir,
|
|
output,
|
|
};
|