Tentando atualizar para o webpack 2, minha compilação falha com o seguinte erro:
ERROR in ./~/ng-table/src/browser/pager.html Module build failed
Importando biblioteca (falha):
import * as ngTable from 'ng-table'
Pacote obrigatório (sucesso):
require('ng-table/bundles/ng-table.js')
configuração do webpack:
'use strict';
const webpack = require('webpack');
const NgAnnotatePlugin = require('ng-annotate-webpack-plugin');
const ExtractTextPlugin = require('extract-text-webpack-plugin');
const HtmlWebpackPlugin = require('html-webpack-plugin');
const argv = require('yargs').argv;
const path = require('path');
module.exports = {
watch: false,
bail: true,
cache: true,
devtool: 'source-map',
entry: './typescript/app/app.ts',
output: {
path: path.resolve(__dirname, 'public'),
filename: 'build/main.bundle.js',
sourceMapFilename: '[name]-[chunkhash].map'
},
resolve: {
extensions: [
'.webpack.js',
'.web.js',
'.ts',
'.js'
],
alias: {
Raven: path.resolve(__dirname, 'node_modules/raven-js/src/raven.js')
}
},
plugins: [
new webpack.DefinePlugin({
'process.env.NODE_ENV': JSON.stringify(process.env.NODE_ENV || 'development'),
}),
new NgAnnotatePlugin({
add: true
}),
new ExtractTextPlugin('build/[name].css'),
new HtmlWebpackPlugin({
filename: 'index.html',
inject: false,
hash: true,
cache: false,
template: 'ejs-loader!./typescript/index.html',
locals: {
environment: ENVIRONMENT,
production: process.env.PRODUCTION,
cdnDomain: CDN_DOMAIN,
backendUrl: BACKEND_URL,
releaseVersion: RELEASE_VERSION
}
}),
new webpack.SourceMapDevToolPlugin({
filename: '[file].map', // if no value is provided the sourcemap is inlined
test: /\.(ts|js)($|\?)/i // process .js and .ts files only
})
],
module: {
rules: [
{
test: /\.ts$/,
loader: 'awesome-typescript-loader'
},
{
test: /\.p?css$/,
loader: ExtractTextPlugin.extract({
fallbackLoader: 'style-loader',
loader: [
'css-loader',
'postcss-loader'
]
})
},
{
test: /\.html$/,
exclude: /index.html$/,
use: [
{
loader: 'ngtemplate-loader',
options: {
relativeTo: path.resolve(__dirname, 'typescript')
}
},
{
loader: 'html-loader'
}
]
}
]
},
devServer: {
historyApiFallback: true
}
}
@faceleg você conseguiu resolver esse problema? Estou atualizando um aplicativo AngularJS 1.5 para Webpack 2 e vejo um GET http://app.finderbox.dev/app/ng-table/pager.html 404 (Not Found)
no log do navegador.
@richtmat não, desisti e tenho usado o webpack 1. Muito interessado em uma solução
Acho que isso pode estar relacionado a ngtemplate-loader
ao especificar relativeTo
. Eu não estou recebendo nenhum erro sobre não encontrar http://app.finderbox.dev/...
embora. Pode estar relacionado: webpack-contrib/html-loader#91. Estou usando [email protected]
e [email protected]
.
No seu test
por .html
, tente remover relativeTo
e executar o Webpack. Para mim, ele compila bem e os modelos ng-table são adicionados ao cache. Abra seu pacote e confira.
Como ainda precisaremos de um prefixo, estou brincando com um bloco de carregador/teste para meu aplicativo e um bloco separado para node_modules.
@mheppner infelizmente, para mim não muda nada (aqui e https://github.com/esvit/ng-table/issues/969).
A única diferença é que os modelos locais também estão errados. A url que termina em .dev
é a minha url de desenvolvimento local, obviamente você não pode ir até lá.
Como eu disse em https://github.com/esvit/ng-table/issues/969 , coloquei o conteúdo do template do bundle em meus arquivos. Os modelos são colocados no cache assim: $templateCache.put('ng-table/pager.html', html);
. Eu ainda luto para descobrir se é um problema de ng-table ou webpack ...
Acima, mesmo erro aqui
Ei, consegui resolver isso alterando como importo ng-table para o meu projeto. Importar diretamente do pacote corrigiu para mim:
import 'ng-table/bundles/ng-table';
Funciona muito bem: import 'of-table/bundles/of-table';
Mesmo problema aqui. Ao importar como
import { ngTableModule } from 'ng-table';
então o cabeçalho e o rodapé não são agrupados, resultando em um HTTP 404.
Alterando a importação para
import 'ng-table/bundles/ng-table';
resolve o problema do cabeçalho/rodapé, mas falta uma falha: os indicadores de classificação ^ e v não são mostrados. A classificação acontece, mas não há indicação visual.
Alguma ideia?
@sargue Isso está alguns meses atrasado, mas eu mesmo tive o mesmo problema com a classificação ^ e v não aparecendo.
Adicionar
import 'ng-table/bundles/ng-table.css';
:)
Obrigado @jheimbouch , não posso tentar porque não estou mais trabalhando nesse projeto. Mas obrigado de qualquer forma, posso ser útil para outra pessoa.
Consegui compilar os arquivos HTML corretamente com o Webpack colocando o seguinte no meu webpack.config.js:
module: {
rules: [
// ...
{ test: /ng-table\/.*\.html$/, use: ['ngtemplate-loader?requireAngular&relativeTo=/src/browser/&prefix=ng-table/', 'html-loader'] }
]
}
Isso também requer os pacotes NPM ngtemplate-loader
e html-loader
. Detalhes completos: https://github.com/esvit/ng-table/issues/969#issuecomment -703458126
Comentários muito úteis
Ei, consegui resolver isso alterando como importo ng-table para o meu projeto. Importar diretamente do pacote corrigiu para mim:
import 'ng-table/bundles/ng-table';