summaryrefslogtreecommitdiff
path: root/src/utils/index.ts
diff options
context:
space:
mode:
Diffstat (limited to 'src/utils/index.ts')
-rw-r--r--src/utils/index.ts30
1 files changed, 30 insertions, 0 deletions
diff --git a/src/utils/index.ts b/src/utils/index.ts
new file mode 100644
index 0000000..d969cb6
--- /dev/null
+++ b/src/utils/index.ts
@@ -0,0 +1,30 @@
+import { logError } from "../api";
+
+/**
+ * Utility for creating a timer that automatically clears after specified timeout
+ * @param callback Function to call when timer completes
+ * @param timeout Timeout in milliseconds
+ * @returns Cleanup function that can be used in useEffect
+ */
+export const createAutoCleanupTimer = (callback: () => void, timeout: number): (() => void) => {
+ const timer = setTimeout(callback, timeout);
+ return () => clearTimeout(timer);
+};
+
+/**
+ * Safe wrapper for async operations to handle errors consistently
+ * @param operation Async operation to perform
+ * @param errorContext Context string for error logging
+ */
+export const safeAsyncOperation = async <T,>(
+ operation: () => Promise<T>,
+ errorContext: string
+): Promise<T | undefined> => {
+ try {
+ return await operation();
+ } catch (e) {
+ logError(`${errorContext}: ${String(e)}`);
+ console.error(e);
+ return undefined;
+ }
+};