const path = require('path'); const webpack = require('webpack'); const nodeExternals = require("webpack-node-externals"); const env = require('dotenv').config({ path: `.env.${process.env.NODE_ENV.toLowerCase()}` }).parsed; /* eslint-env node */ /* * This file runs in a Node context (it's NOT transpiled by Babel), so use only * the ES6 features that are supported by your Node version. https://node.green/ */ // Configuration for your app // https://v2.quasar.dev/quasar-cli-webpack/quasar-config-js const ESLintPlugin = require('eslint-webpack-plugin') const { configure } = require('quasar/wrappers') module.exports = configure(function (ctx) { return { // https://v2.quasar.dev/quasar-cli-webpack/supporting-ts supportTS: false, // https://v2.quasar.dev/quasar-cli-webpack/prefetch-feature preFetch: true, // app boot file (/src/boot) // --> boot files are part of "main.js" // https://v2.quasar.dev/quasar-cli-webpack/boot-files boot: [ 'main', 'directive', { path: 'store', server: false }, //{ path: 'directive', server: false }, //'axios' ], // https://v2.quasar.dev/quasar-cli-webpack/quasar-config-js#Property%3A-css css: [ // 'app.scss' ], // https://github.com/quasarframework/quasar/tree/dev/extras extras: [ // 'ionicons-v4', // 'mdi-v5', // 'fontawesome-v6', // 'eva-icons', // 'themify', // 'line-awesome', // 'roboto-font-latin-ext', // this or either 'roboto-font', NEVER both! // 'roboto-font', // optional, you are not bound to it // 'material-icons' // optional, you are not bound to it ], // Full list of options: https://v2.quasar.dev/quasar-cli-webpack/quasar-config-js#Property%3A-build build: { vueRouterMode: 'history', // available values: 'hash', 'history' env: { ...process.env }, // transpile: false, // publicPath: '/', // Add dependencies for transpiling with Babel (Array of string/regex) // (from node_modules, which are by default not transpiled). // Applies only if "transpile" is set to true. transpileDependencies: [], // rtl: true, // https://quasar.dev/options/rtl-support // preloadChunks: true, // showProgress: false, // gzip: true, // analyze: true, // Options below are automatically set depending on the env, set them if you want to override // extractCSS: false, // https://v2.quasar.dev/quasar-cli-webpack/handling-webpack // "chain" is a webpack-chain object https://github.com/neutrinojs/webpack-chain chainWebpack (chain) { chain.plugin('eslint-webpack-plugin') .use(ESLintPlugin, [{ extensions: ['js', 'vue'] }]) // chain.plugin('normal-module-replacement').use( // new webpack.NormalModuleReplacementPlugin(/settings$/, function(resource) { // resource.request = resource.request.replace(/settings$/, `settings/${process.env.NODE_ENV}`); // }) // ) // require = require('esm')(module); // const settings = require(`./src/settings`); // chain.plugin('robotstxt-webpack-plugin') // .use(new RobotstxtPlugin(settings.robotsTxt)) chain.module.rule('images') .test(/\.(png|jpe?g|gif|svg|webp|avif|ico)(\?.*)?$/) .type('javascript/auto') .use('url-loader') .loader('url-loader') .options({ esModule: false, limit: 16384, name: `assets/img/[name].[hash:8].[ext]` }) chain.module.rule('videos') .test(/\.(mp4|webm|mov)(\?.*)?$/) .type('javascript/auto') .use('url-loader') .loader('url-loader') .options({ esModule: false, limit: 32768, name: `assets/media/[name].[hash:8].[ext]` }) }, extendWebpack (cfg) { cfg.resolve.alias = { ...cfg.resolve.alias, '@': path.resolve(__dirname, './src'), }; }, devtool: 'source-map' }, // Full list of options: https://v2.quasar.dev/quasar-cli-webpack/quasar-config-js#Property%3A-devServer devServer: { server: { type: 'http' }, port: 5173, open: false // opens browser window automatically }, // https://v2.quasar.dev/quasar-cli-webpack/quasar-config-js#Property%3A-framework framework: { config: {}, // iconSet: 'material-icons', // Quasar icon set lang: 'ru', // Quasar language pack // For special cases outside of where the auto-import strategy can have an impact // (like functional components as one of the examples), // you can manually specify Quasar components/directives to be available everywhere: // // components: [], // directives: [], // Quasar plugins plugins: ['Meta'] }, // animations: 'all', // --- includes all animations // https://quasar.dev/options/animations animations: [], // https://v2.quasar.dev/quasar-cli-webpack/developing-ssr/configuring-ssr ssr: { pwa: false, /** * Manually serialize the store state and provide it yourself * as window.__INITIAL_STATE__ to the client-side (through a