feat: 将/support/contact-us由Strapi迁移至Directus

- 修改相关Vue路由
- 添加相应的视图模型与转换方法
This commit is contained in:
2025-10-20 13:13:19 +08:00
parent 440a46850a
commit e48c7fe238
5 changed files with 60 additions and 12 deletions

View File

@ -6,3 +6,4 @@ export * from './useSolutionList';
export * from './useSolution';
export * from './useQuestionList';
export * from './useDocumentList';
export * from './useContactInfo';

View File

@ -0,0 +1,29 @@
import { readSingleton } from '@directus/sdk';
export const useContactInfo = () => {
const { $directus } = useNuxtApp();
const { getDirectusLocale } = useLocalizations();
const locale = getDirectusLocale();
return useAsyncData(`contact-info-${locale}`, async () => {
return await $directus.request(
readSingleton('contact_info', {
fields: [
'id',
{
translations: ['id', 'content'],
},
],
deep: {
translations: {
_filter: {
languages_code: {
_eq: locale,
},
},
},
},
})
);
});
};

View File

@ -0,0 +1,17 @@
/**
* 将 Directus 返回的 ContactInfo 数据转换为 ContactInfoView 视图模型
*
* @param raw: 原始的 ContactInfo 数据
* @returns 转换后的 ContactInfoView 对象
*
* @example
* const view = toContactInfoView(rawContactInfo);
*/
export function toContactInfoView(raw: ContactInfo): ContactInfoView {
const trans = raw.translations?.[0] ?? { content: '' };
return {
id: raw.id,
content: trans.content,
};
}

View File

@ -0,0 +1,10 @@
/**
* 联系信息视图模型
*/
export interface ContactInfoView {
/** 唯一标识符 **/
id: number;
/** 内容 **/
content: string;
}

View File

@ -23,7 +23,7 @@
</div>
<div v-if="!pending" class="page-content">
<markdown-renderer :content="content || ''" />
<markdown-renderer :content="content.content || ''" />
</div>
<div v-else class="loading">
<el-skeleton :rows="5" animated />
@ -32,18 +32,9 @@
</template>
<script setup lang="ts">
const { findOne } = useStrapi();
const { getStrapiLocale } = useLocalizations();
const strapiLocale = getStrapiLocale();
const { data, pending, error } = await useContactInfo();
const { data, pending, error } = useAsyncData('contact-info', () =>
findOne<StrapiContactInfo>('contact-info', undefined, {
populate: '*',
locale: strapiLocale,
})
);
const content = computed(() => data.value?.data.content ?? '');
const content = computed(() => toContactInfoView(data.value));
watch(error, (value) => {
if (value) {