feat: i18n
Add simplified Chinese translation
This commit is contained in:
@@ -10,17 +10,17 @@
|
||||
prepend-icon="vpn_key"
|
||||
color="primary"
|
||||
>
|
||||
Set OpenAI Api Key
|
||||
{{ $t('setApiKey') }}
|
||||
</v-list-item>
|
||||
</template>
|
||||
<v-card>
|
||||
<v-card-title>
|
||||
<span class="text-h5">OpenAI Api Key</span>
|
||||
<span class="text-h5">{{ $t('openAIApiKey') }}</span>
|
||||
</v-card-title>
|
||||
<v-divider></v-divider>
|
||||
<v-card-text>
|
||||
<div>
|
||||
Get a key:
|
||||
{{ $t('getAKey') }}:
|
||||
<a target="_blank" href="https://platform.openai.com/account/api-keys">https://platform.openai.com/account/api-keys</a>
|
||||
</div>
|
||||
<div
|
||||
|
||||
@@ -17,12 +17,12 @@
|
||||
</template>
|
||||
<v-card>
|
||||
<v-card-title>
|
||||
<span class="text-h5">OpenAI Models</span>
|
||||
<span class="text-h5">{{ $t('openAIModels') }}</span>
|
||||
</v-card-title>
|
||||
<v-divider></v-divider>
|
||||
<v-card-text>
|
||||
<div>
|
||||
About the models:
|
||||
{{ $t('aboutTheModels') }}:
|
||||
<a target="_blank" href="https://platform.openai.com/docs/models/overview">https://platform.openai.com/docs/models/overview</a>
|
||||
</div>
|
||||
<div
|
||||
@@ -77,7 +77,7 @@
|
||||
color="primary"
|
||||
@click="save"
|
||||
>
|
||||
Save & Close
|
||||
{{ $t('saveAndClose') }}
|
||||
</v-btn>
|
||||
</v-card-actions>
|
||||
</v-card>
|
||||
@@ -85,6 +85,7 @@
|
||||
</template>
|
||||
|
||||
<script setup>
|
||||
const { $i18n } = useNuxtApp()
|
||||
const dialog = ref(false)
|
||||
const models = useModels()
|
||||
const currentModel = useCurrentModel()
|
||||
@@ -110,7 +111,7 @@ const removeModel = (index) => {
|
||||
}
|
||||
const save = async () => {
|
||||
if (!currentModel.value) {
|
||||
showWarning('Please select at least one model.')
|
||||
showWarning($i18n.t('pleaseSelectAtLeastOneModelDot'))
|
||||
return
|
||||
}
|
||||
setModels(models.value)
|
||||
|
||||
@@ -1,8 +1,8 @@
|
||||
<template>
|
||||
<v-textarea
|
||||
v-model="message"
|
||||
label="Write a message..."
|
||||
placeholder="Write a message..."
|
||||
:label="$t('writeAMessage')"
|
||||
:placeholder="$t('writeAMessage') + '...'"
|
||||
rows="1"
|
||||
:auto-grow="autoGrow"
|
||||
:disabled="disabled"
|
||||
@@ -33,7 +33,7 @@ export default {
|
||||
},
|
||||
computed: {
|
||||
hint() {
|
||||
return isMobile() ? "" : "Press Enter to send your message or Shift+Enter to add a new line.";
|
||||
return isMobile() ? "" : "Press Enter to send your message or Shift+Enter to add a new line";
|
||||
},
|
||||
},
|
||||
watch: {
|
||||
|
||||
@@ -3,11 +3,11 @@
|
||||
<v-row>
|
||||
<v-col cols="12">
|
||||
<div class="text-center">
|
||||
<h2 class="text-h2">Welcome to <span class="text-primary">{{ runtimeConfig.public.appName }}</span></h2>
|
||||
<h2 class="text-h2">{{ $t('welcomeTo') }} <span class="text-primary">{{ runtimeConfig.public.appName }}</span></h2>
|
||||
<p class="text-caption mt-5">
|
||||
{{ runtimeConfig.public.appName }} is an unofficial client for ChatGPT, but uses the official OpenAI API.
|
||||
{{ runtimeConfig.public.appName }} {{ $t('welcomeScreen.introduction1') }}
|
||||
<br>
|
||||
You will need an OpenAI API Key before you can use this client.
|
||||
{{ $t('welcomeScreen.introduction2') }}
|
||||
</p>
|
||||
</div>
|
||||
</v-col>
|
||||
@@ -23,7 +23,7 @@
|
||||
<v-col>
|
||||
<div class="d-flex flex-column align-center">
|
||||
<v-icon icon="sunny"></v-icon>
|
||||
<h3 class="text-h6">Examples</h3>
|
||||
<h3 class="text-h6">{{ $t('welcomeScreen.examples.title') }}</h3>
|
||||
</div>
|
||||
</v-col>
|
||||
</v-row>
|
||||
@@ -37,7 +37,7 @@
|
||||
<v-col>
|
||||
<div class="d-flex flex-column align-center">
|
||||
<v-icon icon="bolt"></v-icon>
|
||||
<h3 class="text-h6">Capabilities</h3>
|
||||
<h3 class="text-h6">{{ $t('welcomeScreen.capabilities.title') }}</h3>
|
||||
</div>
|
||||
</v-col>
|
||||
</v-row>
|
||||
@@ -51,7 +51,7 @@
|
||||
<v-col>
|
||||
<div class="d-flex flex-column align-center">
|
||||
<v-icon icon="warning_amber"></v-icon>
|
||||
<h3 class="text-h6">Limitations</h3>
|
||||
<h3 class="text-h6">{{ $t('welcomeScreen.limitations.title') }}</h3>
|
||||
</div>
|
||||
</v-col>
|
||||
</v-row>
|
||||
@@ -65,19 +65,20 @@
|
||||
|
||||
<script setup>
|
||||
const runtimeConfig = useRuntimeConfig()
|
||||
const { $i18n } = useNuxtApp()
|
||||
const examples = ref([
|
||||
'"Explain quantum computing in simple terms"',
|
||||
'"Got any creative ideas for a 10 year old’s birthday?"',
|
||||
'"How do I make an HTTP request in Javascript?"'
|
||||
$i18n.t('welcomeScreen.examples.item1'),
|
||||
$i18n.t('welcomeScreen.examples.item2'),
|
||||
$i18n.t('welcomeScreen.examples.item3')
|
||||
])
|
||||
const capabilities = ref([
|
||||
'Remembers what user said earlier in the conversation',
|
||||
'Allows user to provide follow-up corrections',
|
||||
'Trained to decline inappropriate requests'
|
||||
$i18n.t('welcomeScreen.capabilities.item1'),
|
||||
$i18n.t('welcomeScreen.capabilities.item2'),
|
||||
$i18n.t('welcomeScreen.capabilities.item3')
|
||||
])
|
||||
const limitations = ref([
|
||||
'May occasionally generate incorrect information',
|
||||
'May occasionally produce harmful instructions or biased content',
|
||||
'Limited knowledge of world and events after 2021'
|
||||
$i18n.t('welcomeScreen.limitations.item1'),
|
||||
$i18n.t('welcomeScreen.limitations.item2'),
|
||||
$i18n.t('welcomeScreen.limitations.item3')
|
||||
])
|
||||
</script>
|
||||
86
components/settings/Languages.vue
Normal file
86
components/settings/Languages.vue
Normal file
@@ -0,0 +1,86 @@
|
||||
<template>
|
||||
<v-dialog
|
||||
v-model="dialog"
|
||||
fullscreen
|
||||
:scrim="false"
|
||||
transition="dialog-bottom-transition"
|
||||
>
|
||||
<template v-slot:activator="{ props }">
|
||||
<v-list-item
|
||||
v-bind="props"
|
||||
rounded="xl"
|
||||
prepend-icon="language"
|
||||
:title="$t('language')"
|
||||
></v-list-item>
|
||||
</template>
|
||||
<v-card>
|
||||
<v-toolbar
|
||||
dark
|
||||
color="primary"
|
||||
>
|
||||
<v-btn
|
||||
icon
|
||||
dark
|
||||
@click="dialog = false"
|
||||
>
|
||||
<v-icon>close</v-icon>
|
||||
</v-btn>
|
||||
<v-toolbar-title>{{ $t('language') }}</v-toolbar-title>
|
||||
<v-spacer></v-spacer>
|
||||
<!-- <v-toolbar-items>-->
|
||||
<!-- <v-btn-->
|
||||
<!-- variant="text"-->
|
||||
<!-- @click="dialog = false"-->
|
||||
<!-- >-->
|
||||
<!-- Save-->
|
||||
<!-- </v-btn>-->
|
||||
<!-- </v-toolbar-items>-->
|
||||
</v-toolbar>
|
||||
<v-list
|
||||
>
|
||||
<!-- <v-list-item-->
|
||||
<!-- title="Use device language"-->
|
||||
<!-- :append-icon="usingDeviceLanguage() ? 'radio_button_checked' : 'radio_button_unchecked'"-->
|
||||
<!-- @click="useDeviceLanguage"-->
|
||||
<!-- >-->
|
||||
<!-- </v-list-item>-->
|
||||
<v-list-item
|
||||
v-for="l in locales"
|
||||
:key="l.code"
|
||||
:title="l.name"
|
||||
:append-icon="radioIcon(l.code)"
|
||||
@click="updateLocale(l.code)"
|
||||
>
|
||||
</v-list-item>
|
||||
</v-list>
|
||||
</v-card>
|
||||
</v-dialog>
|
||||
</template>
|
||||
|
||||
<script setup>
|
||||
const dialog = ref(false)
|
||||
const { locale, locales, setLocale } = useI18n()
|
||||
const { $i18n } = useNuxtApp()
|
||||
|
||||
// const usingDeviceLanguage = () => {
|
||||
// return ($i18n.getLocaleCookie() === undefined || $i18n.getLocaleCookie() === 'undefined')
|
||||
// }
|
||||
|
||||
const updateLocale = (lang) => {
|
||||
setLocale(lang)
|
||||
}
|
||||
|
||||
const radioIcon = (code) => {
|
||||
return code === locale.value ? 'radio_button_checked' : 'radio_button_unchecked'
|
||||
}
|
||||
|
||||
// const useDeviceLanguage = () => {
|
||||
// setLocale($i18n.getBrowserLocale())
|
||||
// $i18n.setLocaleCookie(undefined)
|
||||
// }
|
||||
|
||||
</script>
|
||||
|
||||
<style scoped>
|
||||
|
||||
</style>
|
||||
Reference in New Issue
Block a user