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,172 @@
import request from '@/utils/request';
import type { ApiResult } from '@/api';
import type { Menu, MenuParam } from './model';
import {SERVER_API_URL} from '@/config/setting';
/**
* 查询菜单列表
*/
export async function listMenus(params: MenuParam) {
const res = await request.get<ApiResult<Menu[]>>(
SERVER_API_URL + '/system/menu',
{
params
}
);
if (res.data.code === 0) {
return res.data.data;
}
return Promise.reject(new Error(res.data.message));
}
/**
* 添加菜单
*/
export async function addMenu(data: Menu) {
const res = await request.post<ApiResult<unknown>>(
SERVER_API_URL + '/system/menu',
data
);
if (res.data.code === 0) {
return res.data.message;
}
return Promise.reject(new Error(res.data.message));
}
/**
* 修改菜单
*/
export async function updateMenu(data: Menu) {
const res = await request.put<ApiResult<unknown>>(
SERVER_API_URL + '/system/menu',
data
);
if (res.data.code === 0) {
return res.data.message;
}
return Promise.reject(new Error(res.data.message));
}
/**
* 删除菜单
*/
export async function removeMenu(id?: number) {
const res = await request.delete<ApiResult<unknown>>(
SERVER_API_URL + '/system/menu/' + id
);
if (res.data.code === 0) {
return res.data.message;
}
return Promise.reject(new Error(res.data.message));
}
/**
* 批量删除菜单
*/
export async function removeBatchMenu(data: (number | undefined)[]) {
const res = await request.delete<ApiResult<unknown>>(
SERVER_API_URL + '/system/menu/batch',
{
data
}
);
if (res.data.code === 0) {
return res.data.message;
}
return Promise.reject(new Error(res.data.message));
}
/**
* 按顶级目录批量删除菜单
*/
export async function deleteParentMenu(id?: number) {
const res = await request.delete<ApiResult<unknown>>(
SERVER_API_URL + '/system/menu/deleteParentMenu/' + id
);
if (res.data.code === 0) {
return res.data.message;
}
return Promise.reject(new Error(res.data.message));
}
/**
* 安装应用
*/
export async function installApp(data: any) {
const res = await request.post<ApiResult<unknown>>(
SERVER_API_URL + '/system/menu/install',
data
);
if (res.data.code === 0) {
return res.data.message;
}
return Promise.reject(new Error(res.data.message));
}
/**
* 卸载应用
*/
export async function uninstallApp(data: any) {
const res = await request.post<ApiResult<unknown>>(
SERVER_API_URL + '/system/menu/uninstall',
data
);
if (res.data.code === 0) {
return res.data.message;
}
return Promise.reject(new Error(res.data.message));
}
// 菜单克隆
export async function clone(data: any) {
const res = await request.post<ApiResult<unknown>>(
SERVER_API_URL + '/system/menu/clone',
data
);
if (res.data.code === 0) {
return res.data.message;
}
return Promise.reject(new Error(res.data.message));
}
/**
* 制作插件
*/
export async function createPlug(data: Menu) {
const res = await request.post<ApiResult<unknown>>(
SERVER_API_URL + '/system/menu/plug',
data
);
if (res.data.code === 0) {
return res.data.message;
}
return Promise.reject(new Error(res.data.message));
}
// 安装插件
export async function installPlug(id?: number) {
const res = await request.get<ApiResult<unknown>>(
SERVER_API_URL + '/system/menu/install/' + id
);
if (res.data.code === 0) {
return res.data.message;
}
return Promise.reject(new Error(res.data.message));
}
/**
* 导入备份
*/
export async function importSystemMenu(file: File) {
const formData = new FormData();
formData.append('file', file);
const res = await request.post<ApiResult<unknown>>(
SERVER_API_URL + '/system/menu/import',
formData
);
if (res.data.code === 0) {
return res.data.message;
}
return Promise.reject(new Error(res.data.message));
}