I have an Angular 2 app, which uses systemjs
to map/load.
Importing the rxjs
in the project, and referencing it, is fine, but when the code is deployed, it fails to construct a Subject
variable with message:
"Unhandled Promise rejection: Rx_1.Subject is not a constructor ; Zone: ; Task: Promise.then ; Value: TypeError: Rx_1.Subject is not a constructor".
Rx on systemjs:
(function (global) {
var map = {
'app': 'app',
'@angular': 'js/@angular',
// other libraries
'rxjs': 'js/rxjs',
};
// packages tells the System loader which filename and/or extensions to look for by default (when none are specified)
var packages = {
'app': { main: 'main.js', defaultExtension: 'js' },
'rxjs': { defaultExtension: 'js' }
};
The way I am instantiating the subject:
import { Injectable } from '@angular/core';
import { Subject } from "rxjs/Rx";
@Injectable()
export class MyService {
constructor(private http: Http) {
let b = new Subject<string>(); // exteption HERE
let m = b.asObservable();
b.next("k");
all of rxjs
is loaded fine in the browser.
UPDATE: Looking at this more, if I import Rx
in my Angular service as:
import * as Rx from 'rxjs/Rx';
and than inspect the Rx
object in the console, it just has a default, and __useDefault
property getter.
Everything else, Observable
, Subject
, are accessible through them.
Like doing:
var observable = Rx.Observable.create(function (observer) {
observer.next(1);
});
Gets back and:
VM1083:1 Uncaught TypeError: Cannot read property 'create' of
undefined
Whereas, of course:
var observable = Rx.default.Observable.create(function (observer) {
observer.next(1);
});
works fine.
My project is in TypeScript, I have tried target compilation ES5
and ES6
.
I managed to get unblocked after looking at How to import `Observable` from `Rx` (not angular)
I changed my tsconfig.json module from "system" to "commonjs", and Rx lib files are being transpiled without getters.