feat: Add a welcome screen

This commit is contained in:
Rafi
2023-02-13 20:55:50 +08:00
parent efd1c96852
commit 58e92bfe84
4 changed files with 131 additions and 628 deletions

83
components/Welcome.vue Normal file
View File

@@ -0,0 +1,83 @@
<template>
<v-container>
<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>
<p class="text-caption mt-5">
{{ runtimeConfig.public.appName }} is an unofficial client for ChatGPT, but uses the official OpenAI API.
<br>
You will need an OpenAI API Key before you can use this client.
</p>
</div>
</v-col>
</v-row>
<v-row>
<v-col cols="12" md="10" offset-md="1">
<v-row>
<v-col
cols="12"
md="4"
>
<v-row>
<v-col>
<div class="d-flex flex-column align-center">
<v-icon icon="sunny"></v-icon>
<h3 class="text-h6">Examples</h3>
</div>
</v-col>
</v-row>
<WelcomeCard v-for="example in examples" :content="example" />
</v-col>
<v-col
cols="12"
md="4"
>
<v-row>
<v-col>
<div class="d-flex flex-column align-center">
<v-icon icon="bolt"></v-icon>
<h3 class="text-h6">Capabilities</h3>
</div>
</v-col>
</v-row>
<WelcomeCard v-for="capabilitie in capabilities" :content="capabilitie" />
</v-col>
<v-col
cols="12"
md="4"
>
<v-row>
<v-col>
<div class="d-flex flex-column align-center">
<v-icon icon="warning_amber"></v-icon>
<h3 class="text-h6">Limitations</h3>
</div>
</v-col>
</v-row>
<WelcomeCard v-for="limitation in limitations" :content="limitation" />
</v-col>
</v-row>
</v-col>
</v-row>
</v-container>
</template>
<script setup>
const runtimeConfig = useRuntimeConfig()
const examples = ref([
'"Explain quantum computing in simple terms"',
'"Got any creative ideas for a 10 year olds birthday?"',
'"How do I make an HTTP request in Javascript?"'
])
const capabilities = ref([
'Remembers what user said earlier in the conversation',
'Allows user to provide follow-up corrections',
'Trained to decline inappropriate requests'
])
const limitations = ref([
'May occasionally generate incorrect information',
'May occasionally produce harmful instructions or biased content',
'Limited knowledge of world and events after 2021'
])
</script>

View File

@@ -0,0 +1,24 @@
<template>
<v-row>
<v-col>
<v-hover
v-slot="{ isHovering, props }"
open-delay="100"
>
<v-card
:elevation="isHovering ? 3 : 0"
v-bind="props"
variant="tonal"
>
<v-card-text class="text-center">
{{ content }}
</v-card-text>
</v-card>
</v-hover>
</v-col>
</v-row>
</template>
<script setup>
const props = defineProps(['content'])
</script>

View File

@@ -106,7 +106,10 @@ createNewConversation()
</script> </script>
<template> <template>
<div ref="chatWindow"> <div
v-if="currentConversation.messages.length > 0"
ref="chatWindow"
>
<v-card <v-card
rounded="0" rounded="0"
elevation="0" elevation="0"
@@ -124,6 +127,7 @@ createNewConversation()
</v-card> </v-card>
<div ref="grab" class="w-100" style="height: 150px;"></div> <div ref="grab" class="w-100" style="height: 150px;"></div>
</div> </div>
<Welcome v-else />
<v-footer app class="d-flex flex-column"> <v-footer app class="d-flex flex-column">
<div class="px-md-16 w-100 d-flex align-center"> <div class="px-md-16 w-100 d-flex align-center">
<v-btn <v-btn
@@ -137,7 +141,7 @@ createNewConversation()
</div> </div>
<div class="px-4 py-2 text-disabled text-caption font-weight-light text-center w-100"> <div class="px-4 py-2 text-disabled text-caption font-weight-light text-center w-100">
{{ new Date().getFullYear() }} {{ runtimeConfig.public.appName }} © {{ new Date().getFullYear() }} {{ runtimeConfig.public.appName }}
</div> </div>
</v-footer> </v-footer>
<v-snackbar <v-snackbar

644
yarn.lock

File diff suppressed because it is too large Load Diff