|
4 | 4 | <span class="flex items-center gap-1 text-xl font-black">
|
5 | 5 | {{ t('maevNo') }}
|
6 | 6 | </span>
|
7 |
| - <span> |
8 |
| - {{ statusCode ? `${statusCode} - ` : '' }}{{ statusReason }} |
9 |
| - </span> |
| 7 | + <h1>{{ `${statusCode} - ${statusReason}` }}</h1> |
10 | 8 | </CardStateAlert>
|
11 |
| - <p v-if="statusCode === 403" class="text-center"> |
12 |
| - {{ t('error403Description') }} |
13 |
| - <br /> |
14 |
| - {{ t('error403Hint') }} |
15 |
| - </p> |
| 9 | + <div> |
| 10 | + <p v-if="statusCode === 403" class="text-center"> |
| 11 | + {{ t('error403Description') }} |
| 12 | + <br /> |
| 13 | + {{ t('error403Hint') }} |
| 14 | + </p> |
| 15 | + </div> |
| 16 | + <div> |
| 17 | + <span v-if="description"> |
| 18 | + {{ description }} |
| 19 | + </span> |
| 20 | + <!-- eslint-disable vue/no-v-html --> |
| 21 | + <div v-if="isInDevelopment && stack" v-html="stack" /> |
| 22 | + <!-- eslint-enable vue/no-v-html --> |
| 23 | + </div> |
16 | 24 | <ButtonList class="justify-center">
|
17 | 25 | <ButtonSignIn v-if="statusCode === 403" />
|
18 | 26 | <ButtonHome />
|
|
21 | 29 | </template>
|
22 | 30 |
|
23 | 31 | <script setup lang="ts">
|
24 |
| -import { status } from '@http-util/status-i18n' |
25 |
| -
|
26 | 32 | export interface Props {
|
27 |
| - statusCode?: number |
| 33 | + statusCode: number |
| 34 | + statusMessage?: string |
| 35 | + description?: string |
| 36 | + stack?: string |
28 | 37 | }
|
29 | 38 | const props = withDefaults(defineProps<Props>(), {
|
30 |
| - statusCode: undefined, |
| 39 | + description: undefined, |
| 40 | + statusMessage: undefined, |
| 41 | + stack: undefined, |
31 | 42 | })
|
32 | 43 |
|
33 | 44 | const { locale, t } = useI18n()
|
34 |
| -const { ssrContext } = useNuxtApp() |
35 | 45 |
|
36 |
| -// computations |
37 |
| -const statusReason = computed(() => { |
38 |
| - return status(props.statusCode, locale.value) || (t('error') as string) |
39 |
| -}) |
| 46 | +const isInDevelopment = import.meta.dev |
40 | 47 |
|
41 |
| -// methods |
42 |
| -const init = () => { |
43 |
| - if (ssrContext && props.statusCode) { |
44 |
| - ssrContext.event.node.res.statusCode = props.statusCode |
45 |
| - } |
| 48 | +// page |
| 49 | +const { ssrContext } = useNuxtApp() |
| 50 | +if (ssrContext && props.statusCode) { |
| 51 | + ssrContext.event.node.res.statusCode = props.statusCode |
46 | 52 | }
|
47 | 53 |
|
48 |
| -// initialization |
49 |
| -init() |
50 |
| -</script> |
51 |
| - |
52 |
| -<script lang="ts"> |
53 |
| -export default { |
54 |
| - name: 'AppError', |
55 |
| -} |
| 54 | +// status code |
| 55 | +const { status } = await import('@http-util/status-i18n') |
| 56 | +const statusReason = computed(() => { |
| 57 | + return status(props.statusCode, locale.value) || t('error') |
| 58 | +}) |
56 | 59 | </script>
|
57 | 60 |
|
58 | 61 | <i18n lang="yaml">
|
|
0 commit comments