webpack-bootstrap-ui-kit/webpack.config.common.js

165 lines
4.7 KiB
JavaScript
Raw Normal View History

2021-01-20 22:31:34 +07:00
/*
* Common Environment
*/
2021-08-09 19:41:14 +02:00
const INDEX_NAME = 'test-build';
2021-05-04 00:00:50 +07:00
const YML_PATH = './webpack.yml';
const CONF_VAR = 'App\\Templates\\WebpackTemplateProvider';
2021-01-20 22:31:34 +07:00
const path = require('path');
2021-05-04 00:00:50 +07:00
const fs = require('fs');
const yaml = require('js-yaml');
const webpack = require('webpack');
2021-01-20 22:31:34 +07:00
2021-05-04 00:00:50 +07:00
/*
* Load webpack configuration from webpack.yml
*/
2021-08-02 22:03:17 +02:00
const yml = yaml.load(
2021-05-04 00:00:50 +07:00
fs.readFileSync(path.join(__dirname, YML_PATH), 'utf8'),
);
const conf = yml[CONF_VAR]
let themes = [];
// add themes
if (conf.THEMESDIR) {
const themeDir = conf.THEMESDIR;
const dir = path.resolve(__dirname, themeDir);
if (fs.existsSync(dir)) {
fs.readdirSync(dir).forEach((file) => {
filePath = path.join(themeDir, file);
const stat = fs.statSync(filePath);
if (stat && stat.isDirectory()) {
themes.push(filePath);
}
});
}
}
/* Setup Entries */
2021-01-20 22:31:34 +07:00
const includes = {};
const modules = [
2021-05-04 00:00:50 +07:00
path.resolve(__dirname, conf.APPDIR, conf.SRC),
path.resolve(__dirname, conf.APPDIR, conf.SRC, 'js'),
path.resolve(__dirname, conf.APPDIR, conf.SRC, 'scss'),
path.resolve(__dirname, conf.APPDIR, conf.SRC, 'img'),
path.resolve(__dirname, conf.APPDIR, conf.SRC, 'thirdparty'),
path.resolve(__dirname, 'node_modules'),
path.resolve(__dirname),
path.resolve(__dirname, 'public'),
2021-01-20 22:31:34 +07:00
];
const _addAppFiles = (theme) => {
2021-05-04 00:00:50 +07:00
const dirPath = './' + theme;
let themeName = path.basename(theme);
if (themeName == '.') {
themeName = 'app';
}
2021-08-09 19:41:14 +02:00
if (fs.existsSync(path.join(dirPath, conf.SRC, 'js', INDEX_NAME + '.js'))) {
includes[`${themeName}`] = path.join(dirPath, conf.SRC, 'js', INDEX_NAME + '.js');
2021-05-04 00:00:50 +07:00
} else if (
2021-08-09 19:41:14 +02:00
fs.existsSync(path.join(dirPath, conf.SRC, 'scss', INDEX_NAME + '.scss'))
2021-05-04 00:00:50 +07:00
) {
includes[`${themeName}`] = path.join(
dirPath,
conf.SRC,
'scss',
2021-08-09 19:41:14 +02:00
INDEX_NAME + '.scss',
2021-05-04 00:00:50 +07:00
);
}
modules.push(path.join(dirPath, conf.SRC, 'js'));
modules.push(path.join(dirPath, conf.SRC, 'scss'));
modules.push(path.join(dirPath, conf.SRC, 'img'));
modules.push(path.join(dirPath, conf.SRC, 'thirdparty'));
const _getAllFilesFromFolder = function(dir, includeSubFolders = true) {
const dirPath = path.resolve(__dirname, dir);
let results = [];
fs.readdirSync(dirPath).forEach((file) => {
if (file.charAt(0) === '_') {
return;
}
const filePath = path.join(dirPath, file);
const stat = fs.statSync(filePath);
if (stat && stat.isDirectory() && includeSubFolders) {
results = results.concat(
_getAllFilesFromFolder(filePath, includeSubFolders),
);
} else {
results.push(filePath);
}
});
return results;
};
// add page specific scripts
const typesJSPath = path.join(theme, conf.TYPESJS);
if (fs.existsSync(typesJSPath)) {
const pageScripts = _getAllFilesFromFolder(typesJSPath, true);
pageScripts.forEach((file) => {
includes[`${themeName}_${path.basename(file, '.js')}`] = file;
});
}
// add page specific scss
const typesSCSSPath = path.join(theme, conf.TYPESSCSS);
if (fs.existsSync(typesSCSSPath)) {
const scssIncludes = _getAllFilesFromFolder(typesSCSSPath, true);
scssIncludes.forEach((file) => {
includes[`${themeName}_${path.basename(file, '.scss')}`] = file;
});
}
2021-01-20 22:31:34 +07:00
};
_addAppFiles(conf.APPDIR);
2021-01-31 20:29:24 +07:00
// remove some backend includes
delete includes['app_editor'];
delete includes['app_cms'];
delete includes['app_order'];
2021-01-20 22:31:34 +07:00
// add themes
2021-05-04 00:00:50 +07:00
themes.forEach((theme) => {
_addAppFiles(theme);
2021-01-20 22:31:34 +07:00
});
module.exports = {
2021-05-04 00:00:50 +07:00
configuration: conf,
themes: themes,
webpack: {
entry: includes,
externals: {
// comment out jQuery if you don't use it to prevent bootstrap thinking that there's jQuery present
//jquery: 'jQuery',
react: 'React',
'react-dom': 'ReactDOM',
},
resolve: {
modules: modules,
alias: {
// comment out jQuery if you don't use it to prevent bootstrap thinking that there's jQuery present
/*'window.jQuery': require.resolve('jquery'),
$: require.resolve('jquery'),
jquery: require.resolve('jquery'),
jQuery: require.resolve('jquery'),*/
react: require.resolve('react'),
'react-dom': require.resolve('react-dom'),
},
2021-08-02 22:03:17 +02:00
fallback: {
path: false
},
2021-05-04 00:00:50 +07:00
},
experiments: {
topLevelAwait: true,
},
}
2021-01-20 22:31:34 +07:00
};