feat(pages): 添加文章和商品详情页及API代理配置

- 添加了.dockerignore、.env.example和.gitignore配置文件
- 实现了文件服务器、模块API和服务器API的代理功能
- 创建了动态路由页面用于展示文章列表和详情
- 实现了商品详情页面包括图片展示和价格信息
- 添加了静态页面展示功能支持富文本内容渲染
- 配置了SEO元数据和面包屑导航组件
This commit is contained in:
2026-02-12 13:52:55 +08:00
commit 91e9a8c20f
322 changed files with 48203 additions and 0 deletions

View File

@@ -0,0 +1,42 @@
import { $fetch } from 'ofetch'
import { createError, defineEventHandler, getHeader, getQuery } from 'h3'
import { useRuntimeConfig } from '#imports'
// Frontend-friendly endpoint:
// GET /api/cms-navigation?parentId=xxxx
// Proxies to CMS modules API. Some deployments expose "/cms-navigation", others "/cms/cms-navigation".
export default defineEventHandler(async (event) => {
const config = useRuntimeConfig()
const query = getQuery(event)
const modulesApiBase =
config.public.modulesApiBase || config.public.ApiBase || 'https://cms-api.websoft.top/api'
const tenantId =
getHeader(event, 'tenantid') ||
config.public.tenantId ||
config.public.TenantId ||
'10584'
const authorization = getHeader(event, 'authorization')
const headers = {
TenantId: String(tenantId),
...(authorization ? { Authorization: String(authorization) } : {})
}
const upstreamCandidates = ['/cms-navigation', '/cms/cms-navigation']
let lastError: any
for (const path of upstreamCandidates) {
try {
return await $fetch(path, { baseURL: modulesApiBase, headers, query })
} catch (error: any) {
lastError = error
}
}
throw createError({
statusCode: lastError?.statusCode || lastError?.response?.status || 502,
statusMessage: lastError?.statusMessage || 'Failed to fetch cms navigation'
})
})