You've already forked AstralRinth
forked from didirus/AstralRinth
* feat: init selecting paper+purpur on purchase flow Signed-off-by: Evan Song <theevansong@gmail.com> * feat: properly implement Paper/Purpur in Platform Signed-off-by: Evan Song <theevansong@gmail.com> * chore: correct wording Signed-off-by: Evan Song <theevansong@gmail.com> * feat: redo platform modal Signed-off-by: Evan Song <theevansong@gmail.com> * Switch to HCaptcha for Auth-related captchas (#2945) * Switch to HCaptcha for Auth-related captchas * run fmt * fix hcaptcha not loading * fix: more robust loader dropdown logic Signed-off-by: Evan Song <theevansong@gmail.com> * fix: handle "not yet supported" install err Signed-off-by: Evan Song <theevansong@gmail.com> * chore: fix icon kerfuffles Signed-off-by: Evan Song <theevansong@gmail.com> * chore: improve vanilla install modal title Signed-off-by: Evan Song <theevansong@gmail.com> * fix: spacing Signed-off-by: Evan Song <theevansong@gmail.com> * chore: improve no loader state Signed-off-by: Evan Song <theevansong@gmail.com> * fix: type error Signed-off-by: Evan Song <theevansong@gmail.com> * chore: adjust mod version modal title Signed-off-by: Evan Song <theevansong@gmail.com> * chore: adjust modpack warning copy Signed-off-by: Evan Song <theevansong@gmail.com> * feat: vanilla empty state in content page Signed-off-by: Evan Song <theevansong@gmail.com> * chore: adjust copy Signed-off-by: Evan Song <theevansong@gmail.com> * chore: update icon Signed-off-by: Evan Song <theevansong@gmail.com> * fix: loader type Signed-off-by: Evan Song <theevansong@gmail.com> * fix: loader type Signed-off-by: Evan Song <theevansong@gmail.com> * feat: always show dropdown if possible Signed-off-by: Evan Song <theevansong@gmail.com> * chore: improve spacing Signed-off-by: Evan Song <theevansong@gmail.com> * chore: appear disabled Signed-off-by: Evan Song <theevansong@gmail.com> * h Signed-off-by: Evan Song <theevansong@gmail.com> * chore: if reinstalling, show it on the modal title Signed-off-by: Evan Song <theevansong@gmail.com> * feat: put it in the dropdown, they said Signed-off-by: Evan Song <theevansong@gmail.com> * chore: adjust style Signed-off-by: Evan Song <theevansong@gmail.com> * chore: sort paper-purpur versions desc Signed-off-by: Evan Song <theevansong@gmail.com> * fix: do not consider backup limit in reinstall prompt Signed-off-by: Evan Song <theevansong@gmail.com> * feat: backup locking, plugin support * fix: content type error Signed-off-by: Evan Song <theevansong@gmail.com> * fix: casing Signed-off-by: Evan Song <theevansong@gmail.com> * fix: plugins pt 2 * feat: backups, mrpack * fix: type errors come on Signed-off-by: Evan Song <theevansong@gmail.com> * fix: spacing Signed-off-by: Evan Song <theevansong@gmail.com> * fix: type maxing * chore: show copy button on allocation rows Signed-off-by: Evan Song <theevansong@gmail.com> * feat: suspend improvement --------- Signed-off-by: Evan Song <theevansong@gmail.com> Co-authored-by: Evan Song <theevansong@gmail.com> Co-authored-by: Geometrically <18202329+Geometrically@users.noreply.github.com> Co-authored-by: Jai A <jaiagr+gpg@pm.me> Co-authored-by: Evan Song <52982404+ferothefox@users.noreply.github.com>
123 lines
3.7 KiB
Vue
123 lines
3.7 KiB
Vue
<template>
|
|
<div class="h-full w-full">
|
|
<div class="h-full w-full gap-2 overflow-y-auto">
|
|
<div class="card flex flex-col gap-4">
|
|
<h1 class="m-0 text-lg font-bold text-contrast">Server preferences</h1>
|
|
<p class="m-0">Preferences apply per server and changes are only saved in your browser.</p>
|
|
<div
|
|
v-for="(prefConfig, key) in preferences"
|
|
:key="key"
|
|
class="flex items-center justify-between gap-2"
|
|
>
|
|
<label :for="`pref-${key}`" class="flex flex-col gap-2">
|
|
<div class="flex flex-row gap-2">
|
|
<span class="text-lg font-bold text-contrast">{{ prefConfig.displayName }}</span>
|
|
<div
|
|
v-if="prefConfig.implemented === false"
|
|
class="hidden items-center gap-1 rounded-full bg-table-alternateRow p-1 px-1.5 text-xs font-semibold sm:flex"
|
|
>
|
|
Coming Soon
|
|
</div>
|
|
</div>
|
|
<span>{{ prefConfig.description }}</span>
|
|
</label>
|
|
<input
|
|
:id="`pref-${key}`"
|
|
v-model="newUserPreferences[key]"
|
|
class="switch stylized-toggle flex-none"
|
|
type="checkbox"
|
|
:disabled="prefConfig.implemented === false"
|
|
/>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<UiServersSaveBanner
|
|
:is-visible="hasUnsavedChanges"
|
|
:server="props.server"
|
|
:is-updating="false"
|
|
:save="savePreferences"
|
|
:reset="resetPreferences"
|
|
/>
|
|
</div>
|
|
</template>
|
|
|
|
<script setup lang="ts">
|
|
import { useStorage } from "@vueuse/core";
|
|
import type { Server } from "~/composables/pyroServers";
|
|
|
|
const route = useNativeRoute();
|
|
const serverId = route.params.id as string;
|
|
|
|
const props = defineProps<{
|
|
server: Server<["general", "content", "backups", "network", "startup", "ws", "fs"]>;
|
|
}>();
|
|
|
|
const preferences = {
|
|
ramAsNumber: {
|
|
displayName: "RAM as bytes",
|
|
description:
|
|
"When enabled, RAM will be displayed as bytes instead of a percentage in your server's Overview.",
|
|
implemented: true,
|
|
},
|
|
autoRestart: {
|
|
displayName: "Auto restart",
|
|
description: "When enabled, your server will automatically restart if it crashes.",
|
|
implemented: false,
|
|
},
|
|
powerDontAskAgain: {
|
|
displayName: "Power actions confirmation",
|
|
description: "When enabled, you will be prompted before stopping and restarting your server.",
|
|
implemented: true,
|
|
},
|
|
backupWhileRunning: {
|
|
displayName: "Create backups while running",
|
|
description: "When enabled, backups will be created even if the server is running.",
|
|
implemented: true,
|
|
},
|
|
} as const;
|
|
|
|
type PreferenceKeys = keyof typeof preferences;
|
|
|
|
type UserPreferences = {
|
|
[K in PreferenceKeys]: boolean;
|
|
};
|
|
|
|
const defaultPreferences: UserPreferences = {
|
|
ramAsNumber: false,
|
|
autoRestart: false,
|
|
powerDontAskAgain: false,
|
|
backupWhileRunning: false,
|
|
};
|
|
|
|
const userPreferences = useStorage<UserPreferences>(
|
|
`pyro-server-${serverId}-preferences`,
|
|
defaultPreferences,
|
|
);
|
|
|
|
const newUserPreferences = ref<UserPreferences>(JSON.parse(JSON.stringify(userPreferences.value)));
|
|
|
|
const hasUnsavedChanges = computed(() => {
|
|
return JSON.stringify(newUserPreferences.value) !== JSON.stringify(userPreferences.value);
|
|
});
|
|
|
|
const savePreferences = () => {
|
|
userPreferences.value = { ...newUserPreferences.value };
|
|
addNotification({
|
|
group: "serverOptions",
|
|
type: "success",
|
|
title: "Preferences saved",
|
|
text: "Your preferences have been saved.",
|
|
});
|
|
};
|
|
|
|
const resetPreferences = () => {
|
|
newUserPreferences.value = { ...userPreferences.value };
|
|
};
|
|
</script>
|
|
|
|
<style scoped>
|
|
.stylized-toggle:checked::after {
|
|
background: var(--color-accent-contrast) !important;
|
|
}
|
|
</style>
|