You've already forked AstralRinth
forked from didirus/AstralRinth
a88593fec5
* chore(pyroservers): attempt better error propogation Signed-off-by: Evan Song <theevansong@gmail.com> * chore(pyroservers): introduce deferred modules * fix(pyroservers): synchronize server icon processing Signed-off-by: Evan Song <theevansong@gmail.com> * refactor: server action buttons Signed-off-by: Evan Song <theevansong@gmail.com> * chore: bring back skeleton * fix(startup): populate values on refresh Signed-off-by: Evan Song <theevansong@gmail.com> * chore: properly refresh network Signed-off-by: Evan Song <theevansong@gmail.com> * fix: do not open backup settings modal if fetch failed * fix(platform): only clear selected loader version if selecting a different loader Signed-off-by: Evan Song <theevansong@gmail.com> * feat: parse links in console log * fix: attempt to mitigate power button state flash Signed-off-by: Evan Song <theevansong@gmail.com> * Revert "fix: attempt to mitigate power button state flash" This reverts commit 3ba5c0b4f7f5bacf1576aba5efe42785696a5aed. * refactor: error accumulation builder in PyroServersFetch Signed-off-by: Evan Song <theevansong@gmail.com> * fix: sentence case Signed-off-by: Evan Song <theevansong@gmail.com> * fix(files): await deferred fs Signed-off-by: Evan Song <theevansong@gmail.com> * fix: startup border Signed-off-by: Evan Song <theevansong@gmail.com> * fix: prevent suspended server errors from being overwritten Signed-off-by: Evan Song <theevansong@gmail.com> * fix: add server id copy button to suspended server listing Signed-off-by: Evan Song <theevansong@gmail.com> * fix: refresh behavior Signed-off-by: Evan Song <theevansong@gmail.com> * fix: behavior of server icon in options Signed-off-by: Evan Song <theevansong@gmail.com> * chore: clean Signed-off-by: Evan Song <theevansong@gmail.com> * chore: clean Signed-off-by: Evan Song <theevansong@gmail.com> * fix: prevent error inspector failures from destroying the page Signed-off-by: Evan Song <theevansong@gmail.com> * chore: clean Signed-off-by: Evan Song <theevansong@gmail.com> * chore: remove nexttick wrapper Signed-off-by: Evan Song <theevansong@gmail.com> * fix: ensure file edit gets initted due to deferred module Signed-off-by: Evan Song <theevansong@gmail.com> * refactor: prevent module errors from breaking the layout * chore: clean Signed-off-by: Evan Song <theevansong@gmail.com> --------- Signed-off-by: Evan Song <theevansong@gmail.com>
251 lines
8.4 KiB
Vue
251 lines
8.4 KiB
Vue
<template>
|
|
<div class="relative h-full w-full">
|
|
<div
|
|
v-if="server.startup?.error"
|
|
class="flex w-full flex-col items-center justify-center gap-4 p-4"
|
|
>
|
|
<div class="flex max-w-lg flex-col items-center rounded-3xl bg-bg-raised p-6 shadow-xl">
|
|
<div class="flex flex-col items-center text-center">
|
|
<div class="flex flex-col items-center gap-4">
|
|
<div class="grid place-content-center rounded-full bg-bg-orange p-4">
|
|
<IssuesIcon class="size-12 text-orange" />
|
|
</div>
|
|
<h1 class="m-0 mb-2 w-fit text-4xl font-bold">Failed to load startup settings</h1>
|
|
</div>
|
|
<p class="text-lg text-secondary">
|
|
We couldn't load your server's startup settings. Here's what we know:
|
|
</p>
|
|
<p>
|
|
<span class="break-all font-mono">{{ JSON.stringify(server.startup.error) }}</span>
|
|
</p>
|
|
<ButtonStyled size="large" color="brand" @click="() => server.refresh(['startup'])">
|
|
<button class="mt-6 !w-full">Retry</button>
|
|
</ButtonStyled>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div v-else-if="data" class="flex h-full w-full flex-col gap-4">
|
|
<div
|
|
class="rounded-2xl border-[1px] border-solid border-orange bg-bg-orange p-4 text-contrast"
|
|
>
|
|
These settings are for advanced users. Changing them can break your server.
|
|
</div>
|
|
|
|
<div class="gap-2">
|
|
<div class="card flex flex-col gap-4">
|
|
<div class="flex flex-col justify-between gap-4 sm:flex-row">
|
|
<label for="startup-command-field" class="flex flex-col gap-2">
|
|
<span class="text-lg font-bold text-contrast">Startup command</span>
|
|
<span> The command that runs when your server is started. </span>
|
|
</label>
|
|
<ButtonStyled>
|
|
<button
|
|
:disabled="invocation === startupSettings?.original_invocation"
|
|
class="!w-full sm:!w-auto"
|
|
@click="resetToDefault"
|
|
>
|
|
<UpdatedIcon class="h-5 w-5" />
|
|
Restore default command
|
|
</button>
|
|
</ButtonStyled>
|
|
</div>
|
|
<textarea
|
|
id="startup-command-field"
|
|
v-model="invocation"
|
|
class="min-h-[270px] w-full resize-y font-[family-name:var(--mono-font)]"
|
|
/>
|
|
</div>
|
|
|
|
<div class="card flex flex-col gap-8">
|
|
<div class="flex flex-col gap-4">
|
|
<div class="flex flex-col gap-2">
|
|
<span class="text-lg font-bold text-contrast">Java version</span>
|
|
<span>
|
|
The version of Java that your server will run on. By default, only the Java versions
|
|
compatible with this version of Minecraft are shown. Some mods may require a
|
|
different Java version to work properly.
|
|
</span>
|
|
</div>
|
|
<div class="flex items-center gap-2">
|
|
<input
|
|
id="show-all-versions"
|
|
v-model="showAllVersions"
|
|
class="switch stylized-toggle flex-none"
|
|
type="checkbox"
|
|
/>
|
|
<label for="show-all-versions" class="text-sm">Show all Java versions</label>
|
|
</div>
|
|
<UiServersTeleportDropdownMenu
|
|
:id="'java-version-field'"
|
|
v-model="jdkVersion"
|
|
name="java-version"
|
|
:options="displayedJavaVersions"
|
|
placeholder="Java Version"
|
|
/>
|
|
</div>
|
|
<div class="flex flex-col gap-4">
|
|
<div class="flex flex-col gap-2">
|
|
<span class="text-lg font-bold text-contrast">Runtime</span>
|
|
<span> The Java runtime your server will use. </span>
|
|
</div>
|
|
<UiServersTeleportDropdownMenu
|
|
:id="'runtime-field'"
|
|
v-model="jdkBuild"
|
|
name="runtime"
|
|
:options="['Corretto', 'Temurin', 'GraalVM']"
|
|
placeholder="Runtime"
|
|
/>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<UiServersSaveBanner
|
|
:is-visible="!!hasUnsavedChanges"
|
|
:server="props.server"
|
|
:is-updating="isUpdating"
|
|
:save="saveStartup"
|
|
:reset="resetStartup"
|
|
/>
|
|
</div>
|
|
</template>
|
|
|
|
<script setup lang="ts">
|
|
import { UpdatedIcon, IssuesIcon } from "@modrinth/assets";
|
|
import { ButtonStyled } from "@modrinth/ui";
|
|
import type { Server } from "~/composables/pyroServers";
|
|
|
|
const props = defineProps<{
|
|
server: Server<["general", "content", "backups", "network", "startup", "ws", "fs"]>;
|
|
}>();
|
|
|
|
const data = computed(() => props.server.general);
|
|
const startupSettings = computed(() => props.server.startup);
|
|
const showAllVersions = ref(false);
|
|
|
|
const jdkVersionMap = [
|
|
{ value: "lts8", label: "Java 8" },
|
|
{ value: "lts11", label: "Java 11" },
|
|
{ value: "lts17", label: "Java 17" },
|
|
{ value: "lts21", label: "Java 21" },
|
|
];
|
|
|
|
const jdkBuildMap = [
|
|
{ value: "corretto", label: "Corretto" },
|
|
{ value: "temurin", label: "Temurin" },
|
|
{ value: "graal", label: "GraalVM" },
|
|
];
|
|
|
|
const invocation = ref("");
|
|
const jdkVersion = ref("");
|
|
const jdkBuild = ref("");
|
|
|
|
const originalInvocation = ref("");
|
|
const originalJdkVersion = ref("");
|
|
const originalJdkBuild = ref("");
|
|
|
|
watch(
|
|
startupSettings,
|
|
(newSettings) => {
|
|
if (newSettings) {
|
|
invocation.value = newSettings.invocation;
|
|
originalInvocation.value = newSettings.invocation;
|
|
|
|
const jdkVersionLabel =
|
|
jdkVersionMap.find((v) => v.value === newSettings.jdk_version)?.label || "";
|
|
jdkVersion.value = jdkVersionLabel;
|
|
originalJdkVersion.value = jdkVersionLabel;
|
|
|
|
const jdkBuildLabel = jdkBuildMap.find((v) => v.value === newSettings.jdk_build)?.label || "";
|
|
jdkBuild.value = jdkBuildLabel;
|
|
originalJdkBuild.value = jdkBuildLabel;
|
|
}
|
|
},
|
|
{ immediate: true },
|
|
);
|
|
|
|
const hasUnsavedChanges = computed(
|
|
() =>
|
|
invocation.value !== originalInvocation.value ||
|
|
jdkVersion.value !== originalJdkVersion.value ||
|
|
jdkBuild.value !== originalJdkBuild.value,
|
|
);
|
|
|
|
const isUpdating = ref(false);
|
|
|
|
const compatibleJavaVersions = computed(() => {
|
|
const mcVersion = data.value?.mc_version ?? "";
|
|
if (!mcVersion) return jdkVersionMap.map((v) => v.label);
|
|
|
|
const [major, minor] = mcVersion.split(".").map(Number);
|
|
|
|
if (major >= 1) {
|
|
if (minor >= 20) return ["Java 21"];
|
|
if (minor >= 18) return ["Java 17", "Java 21"];
|
|
if (minor >= 17) return ["Java 16", "Java 17", "Java 21"];
|
|
if (minor >= 12) return ["Java 8", "Java 11", "Java 17", "Java 21"];
|
|
if (minor >= 6) return ["Java 8", "Java 11"];
|
|
}
|
|
|
|
return ["Java 8"];
|
|
});
|
|
|
|
const displayedJavaVersions = computed(() => {
|
|
return showAllVersions.value ? jdkVersionMap.map((v) => v.label) : compatibleJavaVersions.value;
|
|
});
|
|
|
|
const saveStartup = async () => {
|
|
try {
|
|
isUpdating.value = true;
|
|
const invocationValue = invocation.value ?? "";
|
|
const jdkVersionKey = jdkVersionMap.find((v) => v.label === jdkVersion.value)?.value;
|
|
const jdkBuildKey = jdkBuildMap.find((v) => v.label === jdkBuild.value)?.value;
|
|
await props.server.startup?.update(invocationValue, jdkVersionKey as any, jdkBuildKey as any);
|
|
|
|
await new Promise((resolve) => setTimeout(resolve, 10));
|
|
|
|
await props.server.refresh(["startup"]);
|
|
|
|
if (props.server.startup) {
|
|
invocation.value = props.server.startup.invocation;
|
|
jdkVersion.value =
|
|
jdkVersionMap.find((v) => v.value === props.server.startup?.jdk_version)?.label || "";
|
|
jdkBuild.value =
|
|
jdkBuildMap.find((v) => v.value === props.server.startup?.jdk_build)?.label || "";
|
|
}
|
|
|
|
addNotification({
|
|
group: "serverOptions",
|
|
type: "success",
|
|
title: "Server settings updated",
|
|
text: "Your server settings were successfully changed.",
|
|
});
|
|
} catch (error) {
|
|
console.error(error);
|
|
addNotification({
|
|
group: "serverOptions",
|
|
type: "error",
|
|
title: "Failed to update server arguments",
|
|
text: "Please try again later.",
|
|
});
|
|
} finally {
|
|
isUpdating.value = false;
|
|
}
|
|
};
|
|
|
|
const resetStartup = () => {
|
|
invocation.value = originalInvocation.value;
|
|
jdkVersion.value = originalJdkVersion.value;
|
|
jdkBuild.value = originalJdkBuild.value;
|
|
};
|
|
|
|
const resetToDefault = () => {
|
|
invocation.value = startupSettings.value?.original_invocation ?? "";
|
|
};
|
|
</script>
|
|
|
|
<style scoped>
|
|
.stylized-toggle:checked::after {
|
|
background: var(--color-accent-contrast) !important;
|
|
}
|
|
</style>
|