打字脚本+;AngularJSV1:将AngularFactory重写为TypeScript

打字脚本+;AngularJSV1:将AngularFactory重写为TypeScript,angularjs,typescript,interceptor,angularjs-factory,Angularjs,Typescript,Interceptor,Angularjs Factory,我想知道如何将下面的工厂重写为TypeScript代码。以下是原始代码: app.factory('errorInterceptor', function ($q) { return { responseError: function (response) { console.error("Error: " + response.statusText); return $q.reject(response);

我想知道如何将下面的工厂重写为TypeScript代码。以下是原始代码:

app.factory('errorInterceptor', function ($q) {
    return {
        responseError: function (response) {
            console.error("Error: " + response.statusText);
            return $q.reject(response);
        }
    }
});
到目前为止,我已经尝试了以下方法:

 export class errorInterceptor {
    constructor(private $q:ng.IQService) {

    }

    public responseError(response:any){
        console.error("Error: " + response.statusText);

        return this.$q.reject(response);
    }

    public static getFactory(){
        return  errorInterceptor;
    }
}

app.factory('errorInterceptor',errorInterceptor.getFactory());
但我得到了以下错误:

Provider 'errorInterceptor' must return a value from $get factory method.
有什么想法吗?

我使用以下语法:

export class errorInterceptor {
    // to support minification
    static $inject = ["$q"];

    constructor(private $q:ng.IQService) {

    }

    public responseError(response:any){
        console.error("Error: " + response.statusText);

        return this.$q.reject(response);
    }

    //public static getFactory(){
    //    return  errorInterceptor;
    //}
}

//app.factory('errorInterceptor',errorInterceptor.getFactory());
app.service('errorInterceptor',errorInterceptor);
扩展:

这是我用来截取
$http
调用的代码片段(因此它对我来说确实有效)

使用此核心:

电话:


它可以工作,但给我带来了另一个错误:“TypeError:无法读取未定义的属性'reject'。有什么想法吗?当我调试时,它会读到这句话。$q在responseError中未定义。我用截取$http的代码片段扩展了我的答案
module MyModule
{
    var app = angular.module("MyModule");

    export class HttpErrorAspect
    {
        static $inject = ["$q"];

        constructor(private $q: ng.IQService)
        {
        }

        public responseError = (rejection: any): any =>
        {
            // do some magic, e.g. use toaster or alerter
            // to notify about the issue
            ...

            // reject that all
            return this.$q.reject(rejection);
        }
    }

    app.service("HttpErrorFilter", MyModule.HttpErrorAspect);
}
@service(app)
export class UserRolesService {
static $inject: string[] = ["$cookies"];

private $cookies: angular.cookies.ICookiesService;

user: IUser;

GetUser(): IUser {
    return this.user;
}
}
this.userRolesService.GetUser()