You've already forked AstralRinth
* sample languages refactor * feat: consistency + dedupe impl of i18n * fix: broken imports * fix: intl formatted component * fix: use relative imports * fix: imports * fix: comment out incomplete locales + fix imports * feat: cleanup * fix: ui imports * fix: lint * fix: admonition import * make footer a component, fix language reactivity * make copyright notice untranslatable --------- Co-authored-by: Calum H. <contact@cal.engineer>
94 lines
2.3 KiB
Vue
94 lines
2.3 KiB
Vue
<script setup lang="ts">
|
|
import { Combobox, defineMessages, type MessageDescriptor, 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',
|
|
},
|
|
})
|
|
|
|
defineExpose({ resourcePackOptions })
|
|
</script>
|
|
<template>
|
|
<div class="w-[450px]">
|
|
<h2 class="text-lg font-extrabold text-contrast mt-0 mb-1">
|
|
{{ formatMessage(messages.name) }}
|
|
</h2>
|
|
<input
|
|
v-model="name"
|
|
type="text"
|
|
:placeholder="formatMessage(messages.placeholderName)"
|
|
class="w-full"
|
|
autocomplete="off"
|
|
/>
|
|
<h2 class="text-lg font-extrabold text-contrast mt-3 mb-1">
|
|
{{ formatMessage(messages.address) }}
|
|
</h2>
|
|
<input
|
|
v-model="address"
|
|
type="text"
|
|
placeholder="example.modrinth.gg"
|
|
class="w-full"
|
|
autocomplete="off"
|
|
/>
|
|
<h2 class="text-lg font-extrabold text-contrast mt-3 mb-1">
|
|
{{ formatMessage(messages.resourcePack) }}
|
|
</h2>
|
|
<div>
|
|
<Combobox
|
|
v-model="resourcePack"
|
|
:options="
|
|
resourcePackOptions.map((o) => ({
|
|
value: o,
|
|
label: formatMessage(resourcePackOptionMessages[o]),
|
|
}))
|
|
"
|
|
name="Server resource pack"
|
|
:display-value="
|
|
resourcePack
|
|
? formatMessage(resourcePackOptionMessages[resourcePack])
|
|
: 'Select an option'
|
|
"
|
|
/>
|
|
</div>
|
|
</div>
|
|
</template>
|