| import { Observable } from '../Observable'; |
| import { Subscriber } from '../Subscriber'; |
| import { SchedulerLike } from '../types'; |
| import { isFunction } from '../util/isFunction'; |
| |
| /** |
| * Creates an observable that will create an error instance and push it to the consumer as an error |
| * immediately upon subscription. |
| * |
| * <span class="informal">Just errors and does nothing else</span> |
| * |
| *  |
| * |
| * This creation function is useful for creating an observable that will create an error and error every |
| * time it is subscribed to. Generally, inside of most operators when you might want to return an errored |
| * observable, this is unnecessary. In most cases, such as in the inner return of {@link concatMap}, |
| * {@link mergeMap}, {@link defer}, and many others, you can simply throw the error, and RxJS will pick |
| * that up and notify the consumer of the error. |
| * |
| * ## Example |
| * |
| * Create a simple observable that will create a new error with a timestamp and log it |
| * and the message every time you subscribe to it |
| * |
| * ```ts |
| * import { throwError } from 'rxjs'; |
| * |
| * let errorCount = 0; |
| * |
| * const errorWithTimestamp$ = throwError(() => { |
| * const error: any = new Error(`This is error number ${ ++errorCount }`); |
| * error.timestamp = Date.now(); |
| * return error; |
| * }); |
| * |
| * errorWithTimestamp$.subscribe({ |
| * error: err => console.log(err.timestamp, err.message) |
| * }); |
| * |
| * errorWithTimestamp$.subscribe({ |
| * error: err => console.log(err.timestamp, err.message) |
| * }); |
| * |
| * // Logs the timestamp and a new error message for each subscription |
| * ``` |
| * |
| * ### Unnecessary usage |
| * |
| * Using `throwError` inside of an operator or creation function |
| * with a callback, is usually not necessary |
| * |
| * ```ts |
| * import { of, concatMap, timer, throwError } from 'rxjs'; |
| * |
| * const delays$ = of(1000, 2000, Infinity, 3000); |
| * |
| * delays$.pipe( |
| * concatMap(ms => { |
| * if (ms < 10000) { |
| * return timer(ms); |
| * } else { |
| * // This is probably overkill. |
| * return throwError(() => new Error(`Invalid time ${ ms }`)); |
| * } |
| * }) |
| * ) |
| * .subscribe({ |
| * next: console.log, |
| * error: console.error |
| * }); |
| * ``` |
| * |
| * You can just throw the error instead |
| * |
| * ```ts |
| * import { of, concatMap, timer } from 'rxjs'; |
| * |
| * const delays$ = of(1000, 2000, Infinity, 3000); |
| * |
| * delays$.pipe( |
| * concatMap(ms => { |
| * if (ms < 10000) { |
| * return timer(ms); |
| * } else { |
| * // Cleaner and easier to read for most folks. |
| * throw new Error(`Invalid time ${ ms }`); |
| * } |
| * }) |
| * ) |
| * .subscribe({ |
| * next: console.log, |
| * error: console.error |
| * }); |
| * ``` |
| * |
| * @param errorFactory A factory function that will create the error instance that is pushed. |
| */ |
| export function throwError(errorFactory: () => any): Observable<never>; |
| |
| /** |
| * Returns an observable that will error with the specified error immediately upon subscription. |
| * |
| * @param error The error instance to emit |
| * @deprecated Support for passing an error value will be removed in v8. Instead, pass a factory function to `throwError(() => new Error('test'))`. This is |
| * because it will create the error at the moment it should be created and capture a more appropriate stack trace. If |
| * for some reason you need to create the error ahead of time, you can still do that: `const err = new Error('test'); throwError(() => err);`. |
| */ |
| export function throwError(error: any): Observable<never>; |
| |
| /** |
| * Notifies the consumer of an error using a given scheduler by scheduling it at delay `0` upon subscription. |
| * |
| * @param errorOrErrorFactory An error instance or error factory |
| * @param scheduler A scheduler to use to schedule the error notification |
| * @deprecated The `scheduler` parameter will be removed in v8. |
| * Use `throwError` in combination with {@link observeOn}: `throwError(() => new Error('test')).pipe(observeOn(scheduler));`. |
| * Details: https://rxjs.dev/deprecations/scheduler-argument |
| */ |
| export function throwError(errorOrErrorFactory: any, scheduler: SchedulerLike): Observable<never>; |
| |
| export function throwError(errorOrErrorFactory: any, scheduler?: SchedulerLike): Observable<never> { |
| const errorFactory = isFunction(errorOrErrorFactory) ? errorOrErrorFactory : () => errorOrErrorFactory; |
| const init = (subscriber: Subscriber<never>) => subscriber.error(errorFactory()); |
| return new Observable(scheduler ? (subscriber) => scheduler.schedule(init as any, 0, subscriber) : init); |
| } |