const { env } = require('process'); const { readFileSync } = require('fs'); const { resolve } = require('path'); module.exports = (() => { let settings = {}; const assets = {}; const slmModule = (() => { try { const packageJson = readFileSync(resolve(__dirname, 'package.json')) || '{}'; const { dependencies, devDependencies } = JSON.parse(packageJson) || {}; const deps = { ...dependencies, ...devDependencies }; return !(deps.slm && deps['slm-loader']); } catch (_e) { return true; } })() ? {} : { module: { rules: [ { test: /\.slm$/, oneOf: [ { resourceQuery: /^\?vue/, use: [ { loader: 'slm-loader', }, ], }, { use: [ { loader: 'raw-loader', }, { loader: 'slm-loader', }, ], }, ], }, ], }, }; const mode = env.RAILS_ENV || env.NODE_ENV || 'development'; env.RAILS_ENV = mode; env.NODE_ENV = mode; try { /* eslint-disable global-require,import/no-extraneous-dependencies */ const yaml = require('js-yaml'); const { readdirSync, lstatSync } = require('fs'); /* eslint-enable global-require,import/no-extraneous-dependencies */ const config = yaml.safeLoad(readFileSync(resolve('config', 'vue.yml'), 'utf8'))[mode]; const root = resolve(__dirname); const pop = (config.public_output_path || 'vue_assets').replace(/(^\/+|\/+$)/g, ''); const { manifest_output: manifestOutput, js_output: output, alias = {}, devServer, filenameHashing, lintOnSave, runtimeCompiler, transpileDependencies, productionSourceMap, crossorigin, css, parallel, pwa, pluginOptions, } = config; if (devServer && devServer.contentBase) { devServer.contentBase = resolve(root, devServer.contentBase); } const entry = {}; const assetRoot = resolve(root, 'app/assets/vue/entry_points'); const findAllJsFiles = (path) => { readdirSync(path).forEach((fn) => { const filename = resolve(path, fn); const stat = lstatSync(filename); if (stat.isDirectory()) { findAllJsFiles(filename); } else if (stat.isFile() && fn.endsWith('.js')) { entry[filename.slice(assetRoot.length + 1, -3)] = filename; } }); }; try { findAllJsFiles(assetRoot); } catch (_e) { // } settings = { env: mode, root, manifestOutput: manifestOutput && resolve(root, manifestOutput), outputDir: resolve(root, 'public', pop), publicPath: `/${pop}/`, configureWebpack: { entry, output, resolve: { alias: Object.keys(alias).reduce((obj, key) => ({ ...obj, [key]: resolve(root, alias[key]), }), {}), }, ...(slmModule || {}), }, jestModuleNameMapper: Object.keys(alias).reduce((obj, key) => ({ ...obj, [`^${key.replace(/[-[{}()+.,^$#/\s\]]/g, '\\$&')}/(.*)$`]: `/${ alias[key].replace(/^\//, '').replace(/\/$/, '') }/$1`, }), {}), devServer: devServer && { ...devServer, before(app) { app.get('/__manifest/', ({ query }, res) => { const entryPoint = Object.keys(query || {})[0]; res.json(entryPoint === '!!INSPECT!!' ? assets : assets.entrypoints[entryPoint]); }); }, }, filenameHashing, lintOnSave, runtimeCompiler, transpileDependencies, productionSourceMap, crossorigin, css, parallel, pwa, pluginOptions, }; } catch (e) { /* eslint-disable-next-line global-require,import/no-extraneous-dependencies */ const { execSync } = require('child_process'); console.error(mode, e); settings = JSON.parse(execSync('bundle exec rake vue:json_config', { cwd: __dirname, encoding: 'utf8', })); if (slmModule) { Object.assign(settings.configureWebpack, slmModule); } } const getSettingsFromKeys = keys => [].concat(keys).filter(s => s) .reduce((cfg, k) => { const v = settings[k]; return v === undefined ? cfg : { ...cfg, [k]: v }; }, {}); const { jestModuleNameMapper } = settings; const isProd = settings.env === 'production'; return { mode, isProd, manifest: { /* eslint-disable-next-line global-require,import/no-extraneous-dependencies */ plugin: require('webpack-assets-manifest'), options: { assets, entrypoints: true, writeToDisk: !!settings.manifestOutput, publicPath: true, output: settings.manifestOutput || '', }, }, jestModuleNameMapper, getSettings: (keys = Object.keys(settings)) => getSettingsFromKeys(keys), pickUpSettings: ([lines]) => getSettingsFromKeys(lines.split('\n').map(s => s.trim())), }; })();