symfony / webpack-encore

A simple but powerful API for processing & compiling assets built around Webpack
https://symfony.com/doc/current/frontend.html
MIT License
2.23k stars 198 forks source link

Bugs with npm run watch on 0.30.2 #790

Open bastien70 opened 4 years ago

bastien70 commented 4 years ago

Hello, I notice that when I launch npm run watch, the modifications are not taken into account very often. I have to run build to make it work. And if afterwards I retry with run watch, then it gives me back on the server side what I had before the run build, it's very strange.

This is my webpack.config.js :

var Encore = require("@symfony/webpack-encore");
var dotenv = require("dotenv");

// Manually configure the runtime environment if not already configured yet by the "encore" command.
// It's useful when you use tools that rely on webpack.config.js file.
if (!Encore.isRuntimeEnvironmentConfigured()) {
  Encore.configureRuntimeEnvironment(process.env.NODE_ENV || "dev");
}

Encore
  // directory where compiled assets will be stored
  .setOutputPath("public/build/")
  // public path used by the web server to access the output path
  .setPublicPath("/build")
  // only needed for CDN's or sub-directory deploy
  .setManifestKeyPrefix("build/")

  /*
   * ENTRY CONFIG
   *
   * Add 1 entry for each "page" of your app
   * (including one that's included on every page - e.g. "app")
   *
   * Each entry will result in one JavaScript file (e.g. app.js)
   * and one CSS file (e.g. app.css) if your JavaScript imports CSS.
   */
  //.addEntry("app", "./assets/js/app.js")
  //.addEntry('page1', './assets/js/page1.js')
  //.addEntry('page2', './assets/js/page2.js')

  // Sylvia
  .addEntry("app", "./assets/app/app.js")

  // Bootswatch
  .addEntry("bootswatch/flatly", "./assets/bootswatch/flatly/flatly.js")
  .addEntry("bootswatch/minty", "./assets/bootswatch/minty/minty.js")

  // Components
  .addEntry("components", "./assets/components/components.js")

  // Mailer
  .addStyleEntry("email", "./assets/email/email.scss")
  .copyFiles({
    from: "./assets/email/images",
    to: "images/[path][name].[hash:8].[ext]",
  })

  // Libraries
  .addEntry("lib", "./assets/lib/lib.js")

  // Sidebar
  .addEntry("sidebar", "./assets/sidebar/sidebar.js")

  // Stripe
  .addEntry("stripe", "./assets/stripe/stripe.js")

  // Login
  .addEntry("login", "./assets/app/login/login.js")

  // Website
  .addEntry("gaas", "./assets/gaas/main.js")

  .copyFiles({
    from: "./assets/gaas/img",
    to: "gaas/img/[path][name].[hash:8].[ext]",
  })

  // When enabled, Webpack "splits" your files into smaller pieces for greater optimization.
  .splitEntryChunks()

  // will require an extra script tag for runtime.js
  // but, you probably want this, unless you're building a single-page app
  .enableSingleRuntimeChunk()

  /*
   * FEATURE CONFIG
   *
   * Enable & configure other features below. For a full
   * list of features, see:
   * https://symfony.com/doc/current/frontend.html#adding-more-features
   */
  .cleanupOutputBeforeBuild()
  .enableBuildNotifications()
  .enableSourceMaps(!Encore.isProduction())
  // enables hashed filenames (e.g. app.abc123.css)
  .enableVersioning(Encore.isProduction())

  .enableSassLoader()

  // enables @babel/preset-env polyfills
  .configureBabel(() => {}, {
    useBuiltIns: "usage",
    corejs: 3,
  })

  // uncomment if you use TypeScript
  //.enableTypeScriptLoader()

  // uncomment to get integrity="..." attributes on your script & link tags
  // requires WebpackEncoreBundle 1.4 or higher
  //.enableIntegrityHashes(Encore.isProduction())

  // uncomment if you're having problems with a jQuery plugin
  .autoProvidejQuery()

  // uncomment if you use API Platform Admin (composer req api-admin)
  //.enableReactPreset()
  //.addEntry('admin', './assets/js/admin.js')

  // define the environment variables
  .configureDefinePlugin((options) => {
    const env = dotenv.config();

    if (env.error) {
      throw env.error;
    }

    options["process.env"].ALGOLIA_API_KEY = JSON.stringify(
      env.parsed.ALGOLIA_API_KEY
    );
    options["process.env"].ALGOLIA_ID = JSON.stringify(env.parsed.ALGOLIA_ID);

    options['process.env'].STRIPE_PUBLIC_KEY = JSON.stringify(env.parsed.STRIPE_PUBLIC_KEY);
  });
module.exports = Encore.getWebpackConfig();

Unfortunately I have no further information to provide

kalvisbuls commented 4 years ago

I believe I have the same issue, but I can only reproduce it with CSS (both regular and from Vue single file components).