mirror of
https://iceshrimp.dev/Crimekillz/jointrashposs.git
synced 2024-11-22 00:43:50 +01:00
(change) 「問題を報告する」リンクを改善
This commit is contained in:
parent
93f93ffb35
commit
240f337f7b
@ -3,10 +3,13 @@ import { withQuery } from 'ufo';
|
|||||||
export async function getGhIssueUrl(options: {
|
export async function getGhIssueUrl(options: {
|
||||||
lang: string;
|
lang: string;
|
||||||
repoUrl: string;
|
repoUrl: string;
|
||||||
|
additionalInfo?: Record<string, string>;
|
||||||
}) {
|
}) {
|
||||||
// Issue Templateのプレフィル
|
// Issue Templateのプレフィル
|
||||||
let environment = `* Model and OS of the device(s):
|
let environmentArr: string[] = [
|
||||||
* Browser:`;
|
'* Model and OS of the device(s):',
|
||||||
|
'* Browser:',
|
||||||
|
];
|
||||||
let template = '02_visitor-bug-report-en.yml';
|
let template = '02_visitor-bug-report-en.yml';
|
||||||
|
|
||||||
if (options.lang === 'ja') {
|
if (options.lang === 'ja') {
|
||||||
@ -38,33 +41,38 @@ export async function getGhIssueUrl(options: {
|
|||||||
}
|
}
|
||||||
|
|
||||||
const browserData = uaData.fullVersionList.find((item: any) => item.brand.toLowerCase() !== 'not_a brand');
|
const browserData = uaData.fullVersionList.find((item: any) => item.brand.toLowerCase() !== 'not_a brand');
|
||||||
|
|
||||||
const env = [
|
environmentArr = [
|
||||||
`* Model and OS of the device(s): ${uaData.platform} ${osVersion}`,
|
`* Model and OS of the device(s): ${uaData.platform} ${osVersion}`,
|
||||||
`* Browser: ${browserData.brand} ${browserData.version}`,
|
`* Browser: ${browserData.brand} ${browserData.version}`,
|
||||||
`* Viewport Size: ${window.innerWidth}x${window.innerHeight}`,
|
`* Viewport Size: ${window.innerWidth}x${window.innerHeight}`,
|
||||||
`* (UA Detected Using getHighEntropyValues)`,
|
`* (UA Detected Using getHighEntropyValues)`,
|
||||||
(options.lang === 'ja') ? '* 【自動入力済】追記は不要です' : '* [Auto-filled] No need to write additional information.',
|
|
||||||
];
|
];
|
||||||
environment = env.join('\n');
|
|
||||||
} else {
|
} else {
|
||||||
const UAParser = (await import('ua-parser-js')).default;
|
const UAParser = (await import('ua-parser-js')).default;
|
||||||
const ua = new UAParser();
|
const ua = new UAParser();
|
||||||
const uaRes = ua.getResult();
|
const uaRes = ua.getResult();
|
||||||
const env = [
|
|
||||||
|
environmentArr = [
|
||||||
`* Model and OS of the device(s): ${uaRes.os.name} v${uaRes.os.version}`,
|
`* Model and OS of the device(s): ${uaRes.os.name} v${uaRes.os.version}`,
|
||||||
`* Browser: ${uaRes.browser.name} (${uaRes.engine.name}) v${uaRes.browser.version}`,
|
`* Browser: ${uaRes.browser.name} (${uaRes.engine.name}) v${uaRes.browser.version}`,
|
||||||
`* Viewport Size: ${window.innerWidth}x${window.innerHeight}`,
|
`* Viewport Size: ${window.innerWidth}x${window.innerHeight}`,
|
||||||
`* Raw User Agent: ${uaRes.ua}`,
|
`* Raw User Agent: ${uaRes.ua}`,
|
||||||
(options.lang === 'ja') ? '* 【自動入力済】追記は不要です' : '* [Auto-filled] No need to write additional information.',
|
|
||||||
];
|
];
|
||||||
environment = env.join('\n');
|
}
|
||||||
|
if (options.additionalInfo) {
|
||||||
|
environmentArr.push(...Object.entries(options.additionalInfo).map((v) => `* ${v[0]}: ${v[1]}`));
|
||||||
|
}
|
||||||
|
environmentArr.push((options.lang === 'ja') ? '* 【自動入力済】追記は不要です' : '* [Auto-filled] No need to write additional information.');
|
||||||
|
} else {
|
||||||
|
if (options.additionalInfo) {
|
||||||
|
environmentArr.push(...Object.entries(options.additionalInfo).map((v) => `* ${v[0]}: ${v[1]}`));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return withQuery(`${options.repoUrl}/issues/new`, {
|
return withQuery(`${options.repoUrl}/issues/new`, {
|
||||||
template,
|
template,
|
||||||
environment,
|
environment: environmentArr.join('\n'),
|
||||||
labels: 'maybe non-developer,bug?',
|
labels: 'maybe non-developer,bug?',
|
||||||
});
|
});
|
||||||
|
|
||||||
|
17
error.vue
17
error.vue
@ -8,14 +8,23 @@
|
|||||||
></MkAnimBg>
|
></MkAnimBg>
|
||||||
<GNav @toggleNav="isNavOpen = !isNavOpen" :is-open="isNavOpen" />
|
<GNav @toggleNav="isNavOpen = !isNavOpen" :is-open="isNavOpen" />
|
||||||
<div :class="$style.errorContainer" class="relative z-10 flex items-center justify-center">
|
<div :class="$style.errorContainer" class="relative z-10 flex items-center justify-center">
|
||||||
<div class="max-w-xl w-full p-6 mx-6 bg-white/70 dark:bg-white/20 shadow-black/10 shadow-xl rounded-xl">
|
<div class="max-w-xl w-full p-6 mx-6 bg-white/60 dark:bg-white/15 shadow-black/10 shadow-xl rounded-xl">
|
||||||
<img src="https://xn--931a.moe/assets/error.jpg" class="w-32 h-32 rounded-xl mx-auto mb-6" />
|
<img src="https://xn--931a.moe/assets/error.jpg" class="w-32 h-32 rounded-xl mx-auto mb-6" />
|
||||||
<div v-if="error">
|
<div v-if="error">
|
||||||
<h1 class="text-center font-bold text-2xl mb-4">{{ error?.statusCode === 404 ? $t('_error.notFound') : $t('_error.generalError') }}</h1>
|
<h1 class="text-center font-bold text-2xl mb-4">{{ error?.statusCode === 404 ? $t('_error.notFound') : $t('_error.generalError') }}</h1>
|
||||||
<p class="text-center mb-4">{{ error?.statusCode === 404 ? $t('_error.notFoundDesc') : $t('_error.generalErrorDesc') }}</p>
|
<p class="text-center mb-4">{{ error?.statusCode === 404 ? $t('_error.notFoundDesc') : $t('_error.generalErrorDesc') }}</p>
|
||||||
<div class="max-w-lg w-full mx-auto grid grid-cols-1 sm:grid-cols-2 gap-4">
|
<div class="max-w-lg w-full mx-auto grid grid-cols-1 sm:grid-cols-2 gap-4">
|
||||||
<button class="block rounded-full text-center px-4 py-2 border-2 hover:opacity-70" @click="handleError">{{ $t('_error.goToTop') }}</button>
|
<button class="block rounded-full text-center px-4 py-2 border-2 hover:opacity-70" @click="handleError">{{ $t('_error.goToTop') }}</button>
|
||||||
<GNuxtLink class="block rounded-full text-center px-4 py-2 border-2 hover:opacity-70" target="_blank" :to="issueReportLink">{{ $t('_error.reportProblem') }}</GNuxtLink>
|
<GNuxtLink
|
||||||
|
class="block rounded-full text-center px-4 py-2 border-2 hover:opacity-70"
|
||||||
|
:class="!issueReportLink && 'opacity-70'"
|
||||||
|
target="_blank"
|
||||||
|
:to="issueReportLink ?? ''"
|
||||||
|
>{{ $t('_error.reportProblem') }}<div class="inline-block text-sm ml-1">
|
||||||
|
<div v-if="!issueReportLink" class="bi animate-spin border-2 border-accent-500 rounded-full border-t-transparent"></div>
|
||||||
|
<ExtIco v-else />
|
||||||
|
</div>
|
||||||
|
</GNuxtLink>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div v-else class="mx-auto py-5">
|
<div v-else class="mx-auto py-5">
|
||||||
@ -30,6 +39,7 @@
|
|||||||
import type { LocaleObject } from '@nuxtjs/i18n/dist/runtime/composables';
|
import type { LocaleObject } from '@nuxtjs/i18n/dist/runtime/composables';
|
||||||
import NProgress from 'nprogress';
|
import NProgress from 'nprogress';
|
||||||
import { getGhIssueUrl } from './assets/js/misc/get-issue-url';
|
import { getGhIssueUrl } from './assets/js/misc/get-issue-url';
|
||||||
|
import ExtIco from 'bi/box-arrow-up-right.svg';
|
||||||
|
|
||||||
const error = useError();
|
const error = useError();
|
||||||
const colorMode = useColorMode();
|
const colorMode = useColorMode();
|
||||||
@ -64,6 +74,9 @@ const cnHead = (locale.value === 'cn') ? [
|
|||||||
const { data: issueReportLink } = await useAsyncData(`issueReportLink_${locale.value}`, () => getGhIssueUrl({
|
const { data: issueReportLink } = await useAsyncData(`issueReportLink_${locale.value}`, () => getGhIssueUrl({
|
||||||
lang: locale.value,
|
lang: locale.value,
|
||||||
repoUrl: runtimeConfig.public.repositoryUrl,
|
repoUrl: runtimeConfig.public.repositoryUrl,
|
||||||
|
additionalInfo: {
|
||||||
|
'Raw Error': (typeof error.value === 'string') ? error.value : JSON.stringify(error.value),
|
||||||
|
},
|
||||||
}), {
|
}), {
|
||||||
server: false,
|
server: false,
|
||||||
});
|
});
|
||||||
|
Loading…
Reference in New Issue
Block a user