Webpack+Babel building system for StellarExpert React-based UI projects
npm i -D @stellar-expert/webpack-template webpack-cli webpack-dev-server
Create file babel.config.js
in the project root.
const {createBabelConfig} = require('@stellar-expert/webpack-template')
module.exports = createBabelConfig()
//or add additional plugins (only if needed)
module.exports = createBabelConfig([
['@babel/plugin-proposal-class-properties', {loose: true}]
])
Create file webpack-config.js
in the project root.
const path = require('path')
const {initWebpackConfig} = require('@stellar-expert/webpack-template')
module.exports = initWebpackConfig({
entries: {
app: {
import: path.join(__dirname, './app.js'),
htmlTemplate: './static-template/index.html'
}
},
outputPath: './public/',
staticFilesPath: './static/',
scss: {
additionalData: '@import "~@stellar-expert/ui-framework/basic-styles/variables.scss";'
},
define: {
appVersion: pkgInfo.version
},
devServer: {
host: '0.0.0.0',
https: true,
port: 9001
}
})
Add the following two script entries to the project's package.json
{
...
"scripts": {
"build": "webpack --mode=production --config ./webpack-config.js",
"dev-server": "webpack serve --mode development --config ./webpack-config.js"
...
}
...
}
For this building system to properly work with pnpm
package manager,
it is required to create .npmrc
file in the project root.
auto-install-peers=true
shamefully-hoist=true
npm i -D inspectpack
If you have inspectpack
package installed, duplicates will be detected
automatically.