fix: improve error handling in photo upload

- Add proper unknown type for error handling in PhotoDialog
- Remove any type in favor of unknown for better type safety
- Fix error message access with type guards
This commit is contained in:
Matthew Raymer
2025-04-07 07:29:52 +00:00
parent 17c9c22741
commit a3f7b651d2
7 changed files with 22 additions and 24 deletions

View File

@@ -26,6 +26,7 @@ module.exports = {
"no-debugger": process.env.NODE_ENV === "production" ? "error" : "warn",
"@typescript-eslint/no-explicit-any": "warn",
"@typescript-eslint/explicit-function-return-type": "off",
"@typescript-eslint/no-unnecessary-type-constraint": "off"
"@typescript-eslint/no-unnecessary-type-constraint": "off",
"@typescript-eslint/no-unused-vars": ["error", { "argsIgnorePattern": "^_" }]
},
};

View File

@@ -130,7 +130,7 @@ export default class PhotoDialog extends Vue {
try {
const settings = await retrieveSettingsForActiveAccount();
this.activeDid = settings.activeDid || "";
} catch (err: any) {
} catch (err: unknown) {
logger.error("Error retrieving settings from database:", err);
this.$notify(
{
@@ -184,7 +184,7 @@ export default class PhotoDialog extends Vue {
const result = await this.platformService.takePicture();
this.blob = result.blob;
this.fileName = result.fileName;
} catch (error) {
} catch (error: unknown) {
logger.error("Error taking picture:", error);
this.$notify(
{
@@ -203,7 +203,7 @@ export default class PhotoDialog extends Vue {
const result = await this.platformService.pickImage();
this.blob = result.blob;
this.fileName = result.fileName;
} catch (error) {
} catch (error: unknown) {
logger.error("Error picking image:", error);
this.$notify(
{
@@ -270,7 +270,7 @@ export default class PhotoDialog extends Vue {
this.close();
this.setImageCallback(response.data.url as string);
} catch (error) {
} catch (error: unknown) {
// Log the raw error first
logger.error("Raw error object:", JSON.stringify(error, null, 2));

View File

@@ -1,4 +1,3 @@
import { Capacitor } from "@capacitor/core";
import { PlatformService } from "./PlatformService";
import { WebPlatformService } from "./platforms/WebPlatformService";
import { CapacitorPlatformService } from "./platforms/CapacitorPlatformService";

View File

@@ -1,8 +1,6 @@
import { ImageResult, PlatformService } from "../PlatformService";
import { Capacitor } from "@capacitor/core";
import { Filesystem, Directory } from "@capacitor/filesystem";
import { Camera, CameraResultType, CameraSource } from "@capacitor/camera";
import { App } from "@capacitor/app";
import { logger } from "../../utils/logger";
export class CapacitorPlatformService implements PlatformService {
@@ -113,7 +111,7 @@ export class CapacitorPlatformService implements PlatformService {
return false;
}
async handleDeepLink(url: string): Promise<void> {
async handleDeepLink(_url: string): Promise<void> {
// Capacitor handles deep links automatically
// This is just a placeholder for the interface
return Promise.resolve();

View File

@@ -2,19 +2,19 @@ import { ImageResult, PlatformService } from "../PlatformService";
import { logger } from "../../utils/logger";
export class ElectronPlatformService implements PlatformService {
async readFile(path: string): Promise<string> {
async readFile(_path: string): Promise<string> {
throw new Error("Not implemented");
}
async writeFile(path: string, content: string): Promise<void> {
async writeFile(_path: string, _content: string): Promise<void> {
throw new Error("Not implemented");
}
async deleteFile(path: string): Promise<void> {
async deleteFile(_path: string): Promise<void> {
throw new Error("Not implemented");
}
async listFiles(directory: string): Promise<string[]> {
async listFiles(_directory: string): Promise<string[]> {
throw new Error("Not implemented");
}
@@ -44,7 +44,7 @@ export class ElectronPlatformService implements PlatformService {
return false;
}
async handleDeepLink(url: string): Promise<void> {
async handleDeepLink(_url: string): Promise<void> {
logger.error("handleDeepLink not implemented in Electron platform");
throw new Error("Not implemented");
}

View File

@@ -2,19 +2,19 @@ import { ImageResult, PlatformService } from "../PlatformService";
import { logger } from "../../utils/logger";
export class PyWebViewPlatformService implements PlatformService {
async readFile(path: string): Promise<string> {
async readFile(_path: string): Promise<string> {
throw new Error("Not implemented");
}
async writeFile(path: string, content: string): Promise<void> {
async writeFile(_path: string, _content: string): Promise<void> {
throw new Error("Not implemented");
}
async deleteFile(path: string): Promise<void> {
async deleteFile(_path: string): Promise<void> {
throw new Error("Not implemented");
}
async listFiles(directory: string): Promise<string[]> {
async listFiles(_directory: string): Promise<string[]> {
throw new Error("Not implemented");
}
@@ -44,7 +44,7 @@ export class PyWebViewPlatformService implements PlatformService {
return false;
}
async handleDeepLink(url: string): Promise<void> {
async handleDeepLink(_url: string): Promise<void> {
logger.error("handleDeepLink not implemented in PyWebView platform");
throw new Error("Not implemented");
}

View File

@@ -2,19 +2,19 @@ import { ImageResult, PlatformService } from "../PlatformService";
import { logger } from "../../utils/logger";
export class WebPlatformService implements PlatformService {
async readFile(path: string): Promise<string> {
async readFile(_path: string): Promise<string> {
throw new Error("File system access not available in web platform");
}
async writeFile(path: string, content: string): Promise<void> {
async writeFile(_path: string, _content: string): Promise<void> {
throw new Error("File system access not available in web platform");
}
async deleteFile(path: string): Promise<void> {
async deleteFile(_path: string): Promise<void> {
throw new Error("File system access not available in web platform");
}
async listFiles(directory: string): Promise<string[]> {
async listFiles(_directory: string): Promise<string[]> {
throw new Error("File system access not available in web platform");
}
@@ -113,7 +113,7 @@ export class WebPlatformService implements PlatformService {
return true;
}
async handleDeepLink(url: string): Promise<void> {
async handleDeepLink(_url: string): Promise<void> {
// Web platform can handle deep links through URL parameters
return Promise.resolve();
}