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>
157 lines
5.6 KiB
Vue
157 lines
5.6 KiB
Vue
<template>
|
|
<div class="h-full w-full gap-2 overflow-y-auto">
|
|
<div class="card">
|
|
<div class="flex flex-col gap-4">
|
|
<div class="flex flex-col justify-between gap-4 sm:flex-row">
|
|
<label class="flex flex-col gap-2">
|
|
<span class="text-lg font-bold text-contrast">SFTP</span>
|
|
<span> SFTP allows you to access your server's files from outside of Modrinth. </span>
|
|
</label>
|
|
<ButtonStyled>
|
|
<button
|
|
v-tooltip="'This button only works with compatible SFTP clients (e.g. WinSCP)'"
|
|
class="!w-full sm:!w-auto"
|
|
@click="openSftp"
|
|
>
|
|
<ExternalIcon class="h-5 w-5" />
|
|
Launch SFTP
|
|
</button>
|
|
</ButtonStyled>
|
|
</div>
|
|
|
|
<div
|
|
class="flex w-full flex-row justify-between gap-2 rounded-xl bg-table-alternateRow p-4"
|
|
>
|
|
<div class="flex flex-col gap-2">
|
|
<span class="cursor-pointer font-bold text-contrast">
|
|
{{ data?.sftp_host }}
|
|
</span>
|
|
|
|
<span class="text-xs uppercase text-secondary">server address</span>
|
|
</div>
|
|
|
|
<ButtonStyled type="transparent">
|
|
<button
|
|
v-tooltip="'Copy SFTP server address'"
|
|
@click="copyToClipboard('Server address', data?.sftp_host)"
|
|
>
|
|
<CopyIcon class="h-5 w-5 hover:cursor-pointer" />
|
|
</button>
|
|
</ButtonStyled>
|
|
</div>
|
|
<div class="-mt-2 flex flex-col gap-2 sm:mt-0 sm:flex-row">
|
|
<div
|
|
class="flex w-full flex-col justify-center gap-2 rounded-xl bg-table-alternateRow p-4"
|
|
>
|
|
<div class="flex items-center justify-between">
|
|
<span class="font-bold text-contrast">
|
|
{{ data?.sftp_username }}
|
|
</span>
|
|
|
|
<ButtonStyled type="transparent">
|
|
<button
|
|
v-tooltip="'Copy SFTP username'"
|
|
@click="copyToClipboard('Username', data?.sftp_username)"
|
|
>
|
|
<CopyIcon class="h-5 w-5 hover:cursor-pointer" />
|
|
</button>
|
|
</ButtonStyled>
|
|
</div>
|
|
<span class="text-xs uppercase text-secondary">username</span>
|
|
</div>
|
|
<div
|
|
class="flex w-full flex-col justify-center gap-2 rounded-xl bg-table-alternateRow p-4"
|
|
>
|
|
<div class="flex items-center justify-between">
|
|
<span class="font-bold text-contrast">
|
|
{{
|
|
showPassword ? data?.sftp_password : "*".repeat(data?.sftp_password?.length ?? 0)
|
|
}}
|
|
</span>
|
|
|
|
<div class="flex flex-row items-center gap-1">
|
|
<ButtonStyled type="transparent">
|
|
<button
|
|
v-tooltip="'Copy SFTP password'"
|
|
@click="copyToClipboard('Password', data?.sftp_password)"
|
|
>
|
|
<CopyIcon class="h-5 w-5 hover:cursor-pointer" />
|
|
</button>
|
|
</ButtonStyled>
|
|
<ButtonStyled type="transparent">
|
|
<button
|
|
v-tooltip="showPassword ? 'Hide password' : 'Show password'"
|
|
@click="togglePassword"
|
|
>
|
|
<EyeIcon v-if="showPassword" class="h-5 w-5 hover:cursor-pointer" />
|
|
<EyeOffIcon v-else class="h-5 w-5 hover:cursor-pointer" />
|
|
</button>
|
|
</ButtonStyled>
|
|
</div>
|
|
</div>
|
|
<span class="text-xs uppercase text-secondary">password</span>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="card">
|
|
<h2 class="text-xl font-bold">Info</h2>
|
|
<div class="rounded-xl bg-table-alternateRow p-4">
|
|
<table
|
|
class="min-w-full border-collapse overflow-hidden rounded-lg border-2 border-gray-300"
|
|
>
|
|
<tbody>
|
|
<tr v-for="property in properties" :key="property.name">
|
|
<td v-if="property.value !== 'Unknown'" class="py-3">{{ property.name }}</td>
|
|
<td v-if="property.value !== 'Unknown'" class="px-4">
|
|
<UiCopyCode :text="property.value" />
|
|
</td>
|
|
</tr>
|
|
</tbody>
|
|
</table>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</template>
|
|
|
|
<script setup lang="ts">
|
|
import { ButtonStyled } from "@modrinth/ui";
|
|
import { CopyIcon, ExternalIcon, EyeIcon, EyeOffIcon } from "@modrinth/assets";
|
|
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 data = computed(() => props.server.general);
|
|
const showPassword = ref(false);
|
|
|
|
const openSftp = () => {
|
|
const sftpUrl = `sftp://${data.value?.sftp_username}@${data.value?.sftp_host}`;
|
|
window.open(sftpUrl, "_blank");
|
|
};
|
|
|
|
const togglePassword = () => {
|
|
showPassword.value = !showPassword.value;
|
|
};
|
|
|
|
const copyToClipboard = (name: string, textToCopy?: string) => {
|
|
navigator.clipboard.writeText(textToCopy || "");
|
|
addNotification({
|
|
type: "success",
|
|
title: `${name} copied to clipboard!`,
|
|
});
|
|
};
|
|
|
|
const properties = [
|
|
{ name: "Server ID", value: serverId ?? "Unknown" },
|
|
{ name: "Node", value: data.value?.datacenter ?? "Unknown" },
|
|
{ name: "Kind", value: data.value?.upstream?.kind ?? data.value?.loader ?? "Unknown" },
|
|
{ name: "Project ID", value: data.value?.upstream?.project_id ?? "Unknown" },
|
|
{ name: "Version ID", value: data.value?.upstream?.version_id ?? "Unknown" },
|
|
];
|
|
</script>
|