diff --git a/apps/frontend/src/components/ui/servers/FileItem.vue b/apps/frontend/src/components/ui/servers/FileItem.vue index 06db4103e..6d269d8f7 100644 --- a/apps/frontend/src/components/ui/servers/FileItem.vue +++ b/apps/frontend/src/components/ui/servers/FileItem.vue @@ -75,7 +75,7 @@ import { RightArrowIcon, } from "@modrinth/assets"; import { computed, shallowRef, ref } from "vue"; -import { renderToString } from "@vue/server-renderer"; +import { renderToString } from "vue/server-renderer"; import { useRouter, useRoute } from "vue-router"; import { UiServersIconsCogFolderIcon, diff --git a/apps/frontend/src/components/ui/servers/FilesBrowseNavbar.vue b/apps/frontend/src/components/ui/servers/FilesBrowseNavbar.vue index 5cf62b213..c2e5e70a4 100644 --- a/apps/frontend/src/components/ui/servers/FilesBrowseNavbar.vue +++ b/apps/frontend/src/components/ui/servers/FilesBrowseNavbar.vue @@ -2,7 +2,7 @@
- -
- @@ -52,6 +52,7 @@ interface Props { loader: LoaderInfo; currentLoader: string | null; loaderVersion: string | null; + isInstalling?: boolean; } const props = defineProps(); diff --git a/apps/frontend/src/components/ui/servers/LogLine.vue b/apps/frontend/src/components/ui/servers/LogLine.vue new file mode 100644 index 000000000..1e8f4e02b --- /dev/null +++ b/apps/frontend/src/components/ui/servers/LogLine.vue @@ -0,0 +1,91 @@ + + + + + diff --git a/apps/frontend/src/components/ui/servers/LogParser.vue b/apps/frontend/src/components/ui/servers/LogParser.vue deleted file mode 100644 index efea31712..000000000 --- a/apps/frontend/src/components/ui/servers/LogParser.vue +++ /dev/null @@ -1,107 +0,0 @@ - - - - - diff --git a/apps/frontend/src/components/ui/servers/PanelCopyIP.vue b/apps/frontend/src/components/ui/servers/PanelCopyIP.vue deleted file mode 100644 index 6bc45920d..000000000 --- a/apps/frontend/src/components/ui/servers/PanelCopyIP.vue +++ /dev/null @@ -1,31 +0,0 @@ - - - diff --git a/apps/frontend/src/components/ui/servers/PanelOverviewLoading.vue b/apps/frontend/src/components/ui/servers/PanelOverviewLoading.vue deleted file mode 100644 index 7fbe45a37..000000000 --- a/apps/frontend/src/components/ui/servers/PanelOverviewLoading.vue +++ /dev/null @@ -1,77 +0,0 @@ - - - - - diff --git a/apps/frontend/src/components/ui/servers/PanelTerminal.vue b/apps/frontend/src/components/ui/servers/PanelTerminal.vue index 29dfb8c0c..138baa507 100644 --- a/apps/frontend/src/components/ui/servers/PanelTerminal.vue +++ b/apps/frontend/src/components/ui/servers/PanelTerminal.vue @@ -1,141 +1,277 @@ diff --git a/apps/frontend/src/components/ui/servers/PlatformChangeModpackVersionModal.vue b/apps/frontend/src/components/ui/servers/PlatformChangeModpackVersionModal.vue new file mode 100644 index 000000000..ed15a3b5c --- /dev/null +++ b/apps/frontend/src/components/ui/servers/PlatformChangeModpackVersionModal.vue @@ -0,0 +1,164 @@ + + + + + diff --git a/apps/frontend/src/components/ui/servers/PlatformMrpackModal.vue b/apps/frontend/src/components/ui/servers/PlatformMrpackModal.vue new file mode 100644 index 000000000..df5bdb964 --- /dev/null +++ b/apps/frontend/src/components/ui/servers/PlatformMrpackModal.vue @@ -0,0 +1,281 @@ + + + + + diff --git a/apps/frontend/src/components/ui/servers/PlatformVersionSelectModal.vue b/apps/frontend/src/components/ui/servers/PlatformVersionSelectModal.vue new file mode 100644 index 000000000..6bcaef3e1 --- /dev/null +++ b/apps/frontend/src/components/ui/servers/PlatformVersionSelectModal.vue @@ -0,0 +1,551 @@ + + + + + diff --git a/apps/frontend/src/components/ui/servers/ProjectSelect.vue b/apps/frontend/src/components/ui/servers/ProjectSelect.vue deleted file mode 100644 index bdc2e2ebd..000000000 --- a/apps/frontend/src/components/ui/servers/ProjectSelect.vue +++ /dev/null @@ -1,167 +0,0 @@ - - - diff --git a/apps/frontend/src/components/ui/servers/PyroLoading.vue b/apps/frontend/src/components/ui/servers/PyroLoading.vue deleted file mode 100644 index 3c72d239b..000000000 --- a/apps/frontend/src/components/ui/servers/PyroLoading.vue +++ /dev/null @@ -1,94 +0,0 @@ - - - - - diff --git a/apps/frontend/src/components/ui/servers/PyroModal.vue b/apps/frontend/src/components/ui/servers/PyroModal.vue deleted file mode 100644 index 67ea4f17d..000000000 --- a/apps/frontend/src/components/ui/servers/PyroModal.vue +++ /dev/null @@ -1,60 +0,0 @@ - - - diff --git a/apps/frontend/src/components/ui/servers/SaveBanner.vue b/apps/frontend/src/components/ui/servers/SaveBanner.vue index be754f733..65508267e 100644 --- a/apps/frontend/src/components/ui/servers/SaveBanner.vue +++ b/apps/frontend/src/components/ui/servers/SaveBanner.vue @@ -39,7 +39,7 @@ const props = defineProps<{ save: () => void; reset: () => void; isVisible: boolean; - server: Server<["general", "mods", "backups", "network", "startup", "ws", "fs"]>; + server: Server<["general", "content", "backups", "network", "startup", "ws", "fs"]>; }>(); const saveAndRestart = async () => { diff --git a/apps/frontend/src/components/ui/servers/ServerGameLabel.vue b/apps/frontend/src/components/ui/servers/ServerGameLabel.vue index bef037812..6c7fd043d 100644 --- a/apps/frontend/src/components/ui/servers/ServerGameLabel.vue +++ b/apps/frontend/src/components/ui/servers/ServerGameLabel.vue @@ -8,13 +8,19 @@ - {{ game[0].toUpperCase() + game.slice(1) }} {{ mcVersion }} +
+ {{ game[0].toUpperCase() + game.slice(1) }} + {{ mcVersion }} + +
-
- {{ game[0].toUpperCase() + game.slice(1) }} {{ mcVersion }} +
+ {{ game[0].toUpperCase() + game.slice(1) }} + {{ mcVersion }} +
diff --git a/apps/frontend/src/components/ui/servers/ServerInfoLabels.vue b/apps/frontend/src/components/ui/servers/ServerInfoLabels.vue index a23430e78..56f257d32 100644 --- a/apps/frontend/src/components/ui/servers/ServerInfoLabels.vue +++ b/apps/frontend/src/components/ui/servers/ServerInfoLabels.vue @@ -2,19 +2,18 @@
@@ -85,9 +84,12 @@ import type { Project, Server } from "~/types/servers"; const props = defineProps>(); +if (props.server_id) { + await usePyroServer(props.server_id, ["general"]); +} + const showGameLabel = computed(() => !!props.game); const showLoaderLabel = computed(() => !!props.loader); -const showSubdomainLabel = computed(() => !!props.net?.domain); let projectData: Ref; if (props.upstream) { @@ -103,39 +105,11 @@ if (props.upstream) { projectData = ref(null); } -const image = ref(); +const image = useState(`server-icon-${props.server_id}`, () => undefined); -onMounted(async () => { - const auth = (await usePyroFetch(`servers/${props.server_id}/fs`)) as any; - try { - const fileData = await usePyroFetch(`/download?path=/server-icon-original.png`, { - override: auth, - }); - - if (fileData instanceof Blob) { - const canvas = document.createElement("canvas"); - const ctx = canvas.getContext("2d"); - const img = new Image(); - img.src = URL.createObjectURL(fileData); - await new Promise((resolve) => { - img.onload = () => { - canvas.width = 512; - canvas.height = 512; - ctx?.drawImage(img, 0, 0, 512, 512); - const dataURL = canvas.toDataURL("image/png"); - image.value = dataURL; - resolve(); - }; - }); - } - } catch (error) { - if (error instanceof PyroFetchError && error.statusCode === 404) { - image.value = undefined; - } else { - console.error(error); - } - } -}); +if (import.meta.server && projectData.value?.icon_url) { + await usePyroServer(props.server_id!, ["general"]); +} const iconUrl = computed(() => projectData.value?.icon_url || undefined); diff --git a/apps/frontend/src/components/ui/servers/ServerLoaderLabel.vue b/apps/frontend/src/components/ui/servers/ServerLoaderLabel.vue index 13e8694f8..c9920099e 100644 --- a/apps/frontend/src/components/ui/servers/ServerLoaderLabel.vue +++ b/apps/frontend/src/components/ui/servers/ServerLoaderLabel.vue @@ -1,22 +1,33 @@ diff --git a/apps/frontend/src/components/ui/servers/ServerSubdomainLabel.vue b/apps/frontend/src/components/ui/servers/ServerSubdomainLabel.vue index 8f88d1938..d27d44b9f 100644 --- a/apps/frontend/src/components/ui/servers/ServerSubdomainLabel.vue +++ b/apps/frontend/src/components/ui/servers/ServerSubdomainLabel.vue @@ -1,6 +1,6 @@