Ng-table: Problema estranho ao usar o webpack 2

Criado em 17 jan. 2017  ·  11Comentários  ·  Fonte: esvit/ng-table

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
  }
}

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';

Todos 11 comentários

@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

Esta página foi útil?
0 / 5 - 0 avaliações