You've already forked AstralRinth
forked from didirus/AstralRinth
381ea51cce
* fix: files.vue bugs before styling changes * feat: move files tab to shared layout structure * fix: qa * fix: qa * fix: bugs * fix: lint * fix: admonition cleanup with progress + actions * fix: cleanup * fix: modals * fix: admon title * fix: i18n standard * fix: lint + i18n pass * fix: remove transition * fix: type errors * feat: files tab in app * fix: qa * fix: backup item minmax * fix: use ContentPageHeader for server panel * fix: lint * fix: lint * fix: lint * feat: page leave safety * fix: lint * fix: cargo fmt fix * fix: blank in prod * fix: content card table stuff * Revert "fix: blank in prod" This reverts commit 74758fe185cf85a4a20355857f889cb091b97ace. * fix: import * feat: browse worlds/servers flow * fix: worlds tab parity with content tab * fix: perf bug + shader filter pill copy * feat: singleplayer filter * fix: ordering * fix: breadcrumbs * fix: lint * fix: qa * feat: store server proj id when adding to a non-linked instance * fix: lint * fix: i18n + qa * fix: conflict * qa: already installed modal + placeholders not server-specific * fix: qa * fix: add + edit server modals * fix: qa * fix: security * fix: devin flags * fix: lint * chore: change file to break build cache * fix: admon * fix: import path stuff * feat: qa * fix: fmt fmt idiot --------- Signed-off-by: Calum H. <calum@modrinth.com>
104 lines
2.7 KiB
Vue
104 lines
2.7 KiB
Vue
<script setup lang="ts">
|
|
import {
|
|
Combobox,
|
|
defineMessages,
|
|
type MessageDescriptor,
|
|
StyledInput,
|
|
useVIntl,
|
|
} from '@modrinth/ui'
|
|
|
|
import type { ServerPackStatus } from '@/helpers/worlds.ts'
|
|
|
|
const { formatMessage } = useVIntl()
|
|
|
|
const name = defineModel<string>('name')
|
|
const address = defineModel<string>('address')
|
|
const resourcePack = defineModel<ServerPackStatus>('resourcePack')
|
|
|
|
const resourcePackOptions: ServerPackStatus[] = ['enabled', 'prompt', 'disabled']
|
|
|
|
const resourcePackOptionMessages: Record<ServerPackStatus, MessageDescriptor> = defineMessages({
|
|
enabled: {
|
|
id: 'instance.add-server.resource-pack.enabled',
|
|
defaultMessage: 'Enabled',
|
|
},
|
|
prompt: {
|
|
id: 'instance.add-server.resource-pack.prompt',
|
|
defaultMessage: 'Prompt',
|
|
},
|
|
disabled: {
|
|
id: 'instance.add-server.resource-pack.disabled',
|
|
defaultMessage: 'Disabled',
|
|
},
|
|
})
|
|
|
|
const messages = defineMessages({
|
|
name: {
|
|
id: 'instance.server-modal.name',
|
|
defaultMessage: 'Name',
|
|
},
|
|
address: {
|
|
id: 'instance.server-modal.address',
|
|
defaultMessage: 'Address',
|
|
},
|
|
resourcePack: {
|
|
id: 'instance.server-modal.resource-pack',
|
|
defaultMessage: 'Resource pack',
|
|
},
|
|
placeholderName: {
|
|
id: 'instance.server-modal.placeholder-name',
|
|
defaultMessage: 'Minecraft Server',
|
|
},
|
|
placeholderAddress: {
|
|
id: 'app.world.server-modal.placeholder-address',
|
|
defaultMessage: 'example.modrinth.gg',
|
|
},
|
|
selectAnOption: {
|
|
id: 'app.world.server-modal.select-an-option',
|
|
defaultMessage: 'Select an option',
|
|
},
|
|
})
|
|
|
|
defineExpose({ resourcePackOptions })
|
|
</script>
|
|
<template>
|
|
<div class="space-y-4 w-full">
|
|
<label class="flex flex-col gap-2">
|
|
<span class="font-semibold text-contrast">{{ formatMessage(messages.name) }}</span>
|
|
<StyledInput
|
|
v-model="name"
|
|
:placeholder="formatMessage(messages.placeholderName)"
|
|
autocomplete="off"
|
|
wrapper-class="w-full"
|
|
/>
|
|
</label>
|
|
<label class="flex flex-col gap-2">
|
|
<span class="font-semibold text-contrast">{{ formatMessage(messages.address) }}</span>
|
|
<StyledInput
|
|
v-model="address"
|
|
:placeholder="formatMessage(messages.placeholderAddress)"
|
|
autocomplete="off"
|
|
wrapper-class="w-full"
|
|
/>
|
|
</label>
|
|
<label class="flex flex-col gap-2">
|
|
<span class="font-semibold text-contrast">{{ formatMessage(messages.resourcePack) }}</span>
|
|
<Combobox
|
|
v-model="resourcePack"
|
|
:options="
|
|
resourcePackOptions.map((o) => ({
|
|
value: o,
|
|
label: formatMessage(resourcePackOptionMessages[o]),
|
|
}))
|
|
"
|
|
name="Server resource pack"
|
|
:display-value="
|
|
resourcePack
|
|
? formatMessage(resourcePackOptionMessages[resourcePack])
|
|
: formatMessage(messages.selectAnOption)
|
|
"
|
|
/>
|
|
</label>
|
|
</div>
|
|
</template>
|