-
Notifications
You must be signed in to change notification settings - Fork 5
Extend interface to include the type of the response #9
Comments
Can't you already do that? there is a |
The @type decorator is of type ResponseContentType It is not used for specifying the narrow type of the response. But how you want the response treated. To support my idea you would probably need to have this type set to Json because that is the one that can be typed. |
Hmmm.. I see what you mean, it could be done but until I get the time to implement it maybe you could just make yourself a rxjs operator, following the example here https://netbasal.com/create-the-tojson-operator-in-angular-adaac9356e21 function toTypedJSON<T>( classRef: new() => T ): Observable<T> {
return this.map( ( res: Response ) => Object.assign( new classRef, res.json() ) )
}
function toTypedJSONArray<T>( classRef: new() => T ): Observable<T[]> {
return this.map( ( res: Response ) => res.json().map( item => Object.assign( new classRef, item ) ) )
}
...
this.service.batches().toTypedJSONArray(Batch) |
Thanks a lot. I'm very new to typescript/javascript so that is some new ideas for me. Though I'm not concerned about making sure instanceOf works. My Batch type is an interface in any case so AFAIK even with this funky stuff it won't be in the javascript. |
This is a feature request.
I'm wondering if it's possible to do something like:
I would assume that TypedResponse would extend the current response.
With current solution all I need to do is cast the json response to that Batch[]...
It would just be a lot more convenient if this was done inside. Not sure if this is possible of course.
I'm a serious newby with js and ts and have tried to have a look at where this could be put but have no clue where to start...
The text was updated successfully, but these errors were encountered: