feat: Add a welcome screen
This commit is contained in:
83
components/Welcome.vue
Normal file
83
components/Welcome.vue
Normal 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 old’s 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>
|
||||||
24
components/WelcomeCard.vue
Normal file
24
components/WelcomeCard.vue
Normal 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>
|
||||||
@@ -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
|
||||||
|
|||||||
Reference in New Issue
Block a user