Angular 2 Нет ошибки провайдера после объединения

Я обновил свое приложение, чтобы использовать версию выпуска приложения Angular2. Это работает нормально, но я сталкиваюсь с трудностями при запуске приложения из комплектного файла. Я использую gulp, чтобы связать мое приложение в один файл Javascript, в который также встроены шаблоны. Я успешно запустил пакетную версию своего приложения, используя Angular2 RC4, однако с выходной версией я получаю "No provider for AppConfig", AppConfig - один из моих классов, он предоставляется app.module.ts.

Любая помощь будет принята с благодарностью.

gulpfile.js

var basePath = "xxxxxxxxxxxxxxx";
var del = require("del");

var gulp = require("gulp");
var rename = require("gulp-rename");
var uglify = require('gulp-uglify');
var tsc = require("gulp-typescript");
var tsProject = tsc.createProject("tsconfig.json");

var embedTemplates = require("gulp-angular-embed-templates");
var SystemBuilder = require("systemjs-builder");

//Inline templates & transpile into js
gulp.task("js:build", function () {
  return gulp.src("app/**/*.ts", { base: "./app" })
      .pipe(embedTemplates({
        sourceType: "ts",
        basePath: basePath,
        minimize: {
          empty: true,
          quotes: true,
          spare: true
        }
      })) 
      .pipe(tsc(tsProject))
      .js
      .pipe(gulp.dest("build/js"));
});

//Bundle JS files into one file
gulp.task("js:bundle", ["js:build"], function () {
  var builder = new SystemBuilder("build/js", {
    paths: {
      "*": "*.js"
    },
    meta: {
      "@angular/*": {
        build: false
      },
      "rxjs/*": {
        build: false
      }
    }
  });

  return builder.bundle("main", "js/app.bundle.js", { minify: false, mangle: false });
});


gulp.task("js:build:clean", ["js:min"], function () {
  return del([
    "build/js/**/*"
  ]);
});

gulp.task("js:min", ["js:bundle"], function () {
  return gulp.src("js/app.bundle.js")
      .pipe(rename("app.bundle.min.js"))
      .pipe(uglify({ mangle: false }))
      .pipe(gulp.dest("./js/"));
});

gulp.task("ts:clean", function () {
  return del([
    "./app/**/*.js", "./app/**/*.map", "!./app/ng2-file-upload/**/*"
  ]);
});

systemjs.config.js

(function (global) {
  var defaultExtension = "js";

  var map = {
    "app": "/app",
    "@angular": "node_modules/@angular",
    "angular2-in-memory-web-api": "node_modules/angular2-in-memory-web-api"
    ,"rxjs": "node_modules/rxjs"
  };

  var packages = {
    "app": { main: "main.js", defaultExtension: defaultExtension },
    "angular2-in-memory-web-api": { main: "index.js", defaultExtension: defaultExtension }
    ,"rxjs": { defaultExtension: defaultExtension }, 
  };
  var ngPackageNames = [
    "common",
    "compiler",
    "core",
    "forms",
    "http",
    "platform-browser",
    "platform-browser-dynamic",
    "router",
    "upgrade",
  ];

  function packUmd(pkgName) {
    packages["@angular/" + pkgName] = { main: "bundles/" + pkgName + ".umd.min.js", defaultExtension: defaultExtension }; ///bundles/
  }

  var setPackageConfig = packUmd;

  // Add package entries for angular packages
  ngPackageNames.forEach(setPackageConfig);

  var config = {
    bundles: { "/js/app.bundle.min.js?t=@Model.JsFileVersionModifier":  ["main"] },
    map: map,
    packages: packages
  };

  System.config(config);
})(this);

Скрипт из index.html

window["app.config"] = config;

var runApp = function(m) {
    m.RunApplication(config);
}

System.import(toImport).then(runApp, console.error.bind(console));

main.ts

import { platformBrowserDynamic } from '@angular/platform-browser-dynamic';
import { AppModule } from "./app.module";

export function RunApplication() {
  const platform = platformBrowserDynamic();
  platform.bootstrapModule(AppModule);
}

0 ответов

Другие вопросы по тегам