feat: partial user platform support + statusMessage -> message

This commit is contained in:
DecDuck
2025-08-27 11:25:23 +10:00
parent 3af00e085e
commit 8efddc07bc
143 changed files with 831 additions and 593 deletions

View File

@ -727,7 +727,7 @@ function startImport_wrapper() {
importLoading.value = true;
startImport()
.catch((error) => {
importError.value = error.statusMessage ?? t("errors.unknown");
importError.value = error.message ?? t("errors.unknown");
})
.finally(() => {
importLoading.value = false;

View File

@ -202,7 +202,7 @@
:game-name="games.unimportedGames[currentlySelectedGame].game"
:loading="importLoading"
:error="importError"
@import="(v: unknown) => importModes[currentImportMode].import(v)"
@import="(...v: unknown[]) => importModes[currentImportMode].import(...v)"
/>
</div>
</template>
@ -233,7 +233,7 @@ const importModes = shallowRef<{
description: string;
icon: Component;
component: Component;
import: (v: unknown) => void;
import: (...v: unknown[]) => void;
};
}>({
Game: {
@ -249,7 +249,7 @@ const importModes = shallowRef<{
"Redistributables are packaged dependencies for games, that are installed alongside and required to play certain games.",
icon: ArchiveBoxIcon,
component: ImportRedist,
import: importRedist as (v: unknown) => void,
import: importRedist as (v: unknown, k: unknown) => void,
},
});
@ -303,12 +303,12 @@ async function importGame_wrapper(
} catch (error) {
console.warn(error);
importError.value =
(error as FetchError)?.statusMessage || t("errors.unknown");
(error as FetchError)?.message || t("errors.unknown");
}
importLoading.value = false;
}
async function importRedist(data: object) {
async function importRedist(data: object, platform: object | undefined) {
importLoading.value = true;
importError.value = undefined;
try {
@ -316,7 +316,19 @@ async function importRedist(data: object) {
const formData = new FormData();
for (const [key, value] of Object.entries(data)) {
formData.append(key, value);
formData.append(
key,
typeof value === "object" ? JSON.stringify(value) : value,
);
}
if (platform) {
for (const [key, value] of Object.entries(platform)) {
formData.append(
`platform.${key}`,
typeof value === "object" ? JSON.stringify(value) : value,
);
}
}
formData.append("library", option.library.id);
@ -335,7 +347,7 @@ async function importRedist(data: object) {
} catch (error) {
console.warn(error);
importError.value =
(error as FetchError)?.statusMessage || t("errors.unknown");
(error as FetchError)?.message || t("errors.unknown");
}
importLoading.value = false;
}

View File

@ -412,7 +412,7 @@ function performActionSource_wrapper() {
})
.catch((e) => {
if (e instanceof FetchError) {
modalError.value = e.statusMessage ?? e.message;
modalError.value = e.message ?? e.message;
} else {
modalError.value = e as string;
}
@ -449,8 +449,8 @@ async function deleteSource(index: number) {
{
title: t("errors.library.source.delete.title"),
description: t("errors.library.source.delete.desc", [
// @ts-expect-error attempt to display statusMessage on error
e?.statusMessage ?? t("errors.unknown"),
// @ts-expect-error attempt to display message on error
e?.message ?? t("errors.unknown"),
]),
},
(_, c) => c(),

View File

@ -96,7 +96,7 @@ async function saveSettings() {
title: `Failed to save settings.`,
description:
e instanceof FetchError
? (e.statusMessage ?? e.message)
? (e.message)
: (e as string).toString(),
},
(_, c) => c(),

View File

@ -184,7 +184,7 @@ if (route.query.payload) {
} catch {
throw createError({
statusCode: 400,
statusMessage: "Failed to parse the token create payload.",
message: "Failed to parse the token create payload.",
fatal: true,
});
}

View File

@ -502,7 +502,7 @@ function invite_wrapper() {
invitations.value.push(invitation);
})
.catch((response) => {
const message = response.statusMessage || t("errors.unknown");
const message = response.message || t("errors.unknown");
error.value = message;
})
.finally(() => {