aboutsummaryrefslogtreecommitdiff
path: root/Timeline/ClientApp/src/app/utilities/rxjs.ts
diff options
context:
space:
mode:
authorcrupest <crupest@outlook.com>2020-07-26 15:02:55 +0800
committercrupest <crupest@outlook.com>2020-07-26 15:02:55 +0800
commitf5d10683a1edeba4dabe148ff7aa682c044f7496 (patch)
treed8f7edae96baa26823dee80ccc9329a23ac04c3c /Timeline/ClientApp/src/app/utilities/rxjs.ts
parent7753c9cad23b06c2acdd908a5a7cc3863bfa6b61 (diff)
downloadtimeline-f5d10683a1edeba4dabe148ff7aa682c044f7496.tar.gz
timeline-f5d10683a1edeba4dabe148ff7aa682c044f7496.tar.bz2
timeline-f5d10683a1edeba4dabe148ff7aa682c044f7496.zip
Merge front end repo
Diffstat (limited to 'Timeline/ClientApp/src/app/utilities/rxjs.ts')
-rw-r--r--Timeline/ClientApp/src/app/utilities/rxjs.ts14
1 files changed, 14 insertions, 0 deletions
diff --git a/Timeline/ClientApp/src/app/utilities/rxjs.ts b/Timeline/ClientApp/src/app/utilities/rxjs.ts
new file mode 100644
index 00000000..1be49164
--- /dev/null
+++ b/Timeline/ClientApp/src/app/utilities/rxjs.ts
@@ -0,0 +1,14 @@
+import { OperatorFunction } from 'rxjs';
+import { catchError } from 'rxjs/operators';
+
+export function convertError<T, NewError>(
+ oldErrorType: { new (...args: never[]): unknown },
+ newErrorType: { new (): NewError }
+): OperatorFunction<T, T> {
+ return catchError((error) => {
+ if (error instanceof oldErrorType) {
+ throw new newErrorType();
+ }
+ throw error;
+ });
+}