Window not defined with Angular4 + AoT + Webpack2
I have an angular4 app that uses webpack and works fine with JiT, but now I'm trying to get it to work with AoT and I'm having problems. Specifically, I am getting the following error:
ERROR in window is not defined
ERROR in ./src/app/main/main.ts
Module not found: Error: Can't resolve './../../../aot-main/src/app/main/app.module.ngfactory' in 'W:\<Full Path to App>\src\app\main'
resolve './../../../aot-main/src/app/main/app.module.ngfactory' in 'W:\<Full Path to App>\src\app\main'
using description file: W:\<Full Path to App>\package.json (relative path: ./src/app/main)
Field 'browser' doesn't contain a valid alias configuration
after using description file: W:\<Full Path to App>\package.json (relative path: ./src/app/main)
using description file: W:\<Full Path to App>\package.json (relative path: ./aot-main/src/app/main/app.module.ngfactory)
no extension
Field 'browser' doesn't contain a valid alias configuration
W:\<Full Path to App>\aot-main\src\app\main\app.module.ngfactory doesn't exist
.ts
Field 'browser' doesn't contain a valid alias configuration
W:\<Full Path to App>\aot-main\src\app\main\app.module.ngfactory.ts doesn't exist
.js
Field 'browser' doesn't contain a valid alias configuration
W:\<Full Path to App>\aot-main\src\app\main\app.module.ngfactory.js doesn't exist
as directory
W:\<Full Path to App>\aot-main\src\app\main\app.module.ngfactory doesn't exist
[W:\<Full Path to App>\aot-main\src\app\main\app.module.ngfactory]
[W:\<Full Path to App>\aot-main\src\app\main\app.module.ngfactory.ts]
[W:\<Full Path to App>\aot-main\src\app\main\app.module.ngfactory.js]
[W:\<Full Path to App>\aot-main\src\app\main\app.module.ngfactory]
@ ./src/app/main/main.ts 3:0-91
Assuming the first line was bound using the global "window" variable, I went through and replaced each reference to it with a service reference:
import { Injectable } from '@angular/core';
function getWindow(): any {
return window;
}
@Injectable()
export class WindowRefService {
get nativeWindow(): any {
return getWindow();
}
}
I'm sure I have all the places where I use the window variable, but I can't get past the error and the information provided with the error seems to be useless as it doesn't tell me where the problem is.
Here is my webpack config file:
var webpack = require('webpack');
var ngToolsWebpack = require('@ngtools/webpack');
var HtmlWebpackPlugin = require('html-webpack-plugin');
var helpers = require('./helpers');
require('es6-promise').polyfill();
module.exports = {
entry: {
MyApp: './src/app/main/main.ts',
polyfills: './src/app/main/polyfills.ts',
vendor: './src/app/main/vendor.ts'
},
resolve: {
extensions: ['.ts', '.js']
},
output: {
path: helpers.root('app'),
publicPath: 'https://localhost:8080/app/',
filename: 'js/[name].js?[hash]',
chunkFilename: 'js/MyApp-[id].chunk.js?[hash]'
},
module: {
rules: [
{
test: /\.ts$/,
use: [{ loader: '@ngtools/webpack' }, { loader: 'angular-router-loader' }]
},
{ test: /\.html$/,
use: [{ loader: 'html-loader' }]
},
{
test: /\.(png|jpe?g|gif|svg|woff|woff2|ttf|eot|ico)$/,
use: [{ loader: 'file-loader?name=images/[name].[ext]' }]
},
{
test: /\.scss$/,
use: ['to-string-loader', 'style-loader', 'css-loader?sourceMap', 'sass-loader?sourceMap']
}
]
},
plugins: [
new webpack.optimize.CommonsChunkPlugin({
name: ['MyApp', 'vendor', 'polyfills']
}),
new HtmlWebpackPlugin({
template: 'src/app/main/index.html'
}),
new webpack.ContextReplacementPlugin(
/angular(\\|\/)core(\\|\/)@angular/,
helpers.root('doesnotexist')
),
new ngToolsWebpack.AotPlugin({
tsConfigPath: './tsconfig.main.aot.json',
entryModule: './src/app/main/app.module#AppModule'
})
]
};
Is there a better way to determine what is actually causing it to fail?
UPDATE 7/19/2017: I found that if I change the .scss loader in the webpack config to the following (and remove the angular-router-loader from the .ts rule), then I collect it, but my styles are not showing:
use: ['raw-loader', 'sass-loader?sourceMap']
As soon as I add one of the other loaders the error results. Any idea how to show my .scss styles?
source to share
It might be a little late, but I recently ran into this same problem and found a solution and I have to say ... holy guacamole is an ERROR error in the window undefined in delusion!
The main reason? Style loader. It looks like the style loader can only be created client-side (or locally). When you try to do AOT builds it acts like a server side build and it fails because of this issue: https://github.com/webpack-contrib/style-loader/issues/109
Decision? Replace style loader with isomorphic style loader: https://github.com/creeperyang/iso-morphic-style-loader
{
test: /\.scss$/,
use: ['to-string-loader', 'iso-morphic-style-loader', 'css-loader?sourceMap', 'sass-loader?sourceMap']
}
source to share