const argv = require('yargs').argv const path = require('path') const config_path = path.resolve(argv.config || './config.js') const config = require(config_path) module.exports = { mode: 'universal', /* ** Headers of the page */ head: { title: config.title, meta: [ { charset: 'utf-8' }, { name: 'viewport', content: 'width=device-width, initial-scale=1' }, { hid: 'description', name: 'description', content: config.description } ], link: [{ rel: 'icon', type: 'image/x-icon', href: '/favicon.ico' }] }, dev: (process.env.NODE_ENV !== 'production'), serverMiddleware: [ { path: '/api', handler: '@/server/api/index.js' } ], /* ** Customize the progress-bar color */ // loading: { color: '#fff' }, /* ** Global CSS */ css: [ 'bootstrap/dist/css/bootstrap.css', 'element-ui/lib/theme-chalk/index.css' ], env: { baseurl: config.baseurl, title: config.title, description: config.description, locale: config.locale }, /* ** Plugins to load before mounting the App */ plugins: [ '@/plugins/element-ui', // UI library -> https://element.eleme.io/#/en-US/ '@/plugins/filters', // text filters, datetime, etc. '@/plugins/i18n', // localization plugin '@/plugins/vue-awesome', // icon { src: '@/plugins/v-calendar', ssr: false } // calendar, TO-REDO ], /* ** Nuxt.js modules */ modules: [ // Doc: https://axios.nuxtjs.org/usage '@nuxtjs/axios', '@nuxtjs/auth' ], /* ** Axios module configuration */ axios: { baseURL: config.baseurl + '/api', browserBaseURL: config.baseurl + '/api', prefix: '/api' // credentials: true // See https://github.com/nuxt-community/axios-module#options }, auth: { strategies: { local: { endpoints: { login: { url: '/auth/login', method: 'post', propertyName: 'token' }, logout: false, user: { url: '/auth/user', method: 'get', propertyName: false } } } } }, /* ** Build configuration */ build: { optimization: { splitChunks: { cacheGroups: { element: { test: /[\\/]node_modules[\\/](element-ui)[\\/]/, name: 'element-ui', chunks: 'all' } } } }, transpile: [/^element-ui/, /^vue-awesome/], splitChunks: { layouts: true }, cache: true, parallel: true } }