feat(app): 初始化项目配置和页面结构

- 添加 .dockerignore 和 .env.example 配置文件
- 添加 .gitignore 忽略规则配置
- 创建服务端代理API路由(_file、_modules、_server)
- 集成 Ant Design Vue 组件库并配置SSR样式提取
- 定义API响应类型封装
- 创建基础布局组件(blank、console)
- 实现应用中心页面和组件(AppsCenter)
- 添加文章列表测试页面
- 配置控制台导航菜单结构
- 实现控制台头部组件
- 创建联系页面表单
This commit is contained in:
2026-01-17 18:23:37 +08:00
commit 5e26fdc7fb
439 changed files with 56219 additions and 0 deletions

View File

@@ -0,0 +1,125 @@
import request from '@/utils/request';
import type { ApiResult, PageResult } from '@/api';
import type { Plug, PlugParam } from './model/index';
import { SERVER_API_URL } from '@/config/setting';
/**
* 分页查询应用
*/
export async function pagePlug(params: PlugParam) {
const res = await request.get<ApiResult<PageResult<Plug>>>(
SERVER_API_URL + '/system/plug/page',
{
params
}
);
if (res.data.code === 0) {
return res.data.data;
}
return Promise.reject(new Error(res.data.message));
}
/**
* 查询应用列表
*/
export async function listPlug(params?: PlugParam) {
const res = await request.get<ApiResult<Plug[]>>(
SERVER_API_URL + '/system/plug',
{
params
}
);
if (res.data.code === 0 && res.data.data) {
return res.data.data;
}
return Promise.reject(new Error(res.data.message));
}
/**
* 根据id查询应用
*/
export async function getPlug(id: number) {
const res = await request.get<ApiResult<Plug>>(
SERVER_API_URL + '/system/plug/' + id
);
if (res.data.code === 0 && res.data.data) {
return res.data.data;
}
return Promise.reject(new Error(res.data.message));
}
/**
* 修改应用
*/
export async function updatePlug(data: Plug) {
const res = await request.put<ApiResult<unknown>>(
SERVER_API_URL + '/system/plug',
data
);
if (res.data.code === 0) {
return res.data.message;
}
return Promise.reject(new Error(res.data.message));
}
// 排行榜
export async function ranking(params?: PlugParam) {
const res = await request.get<ApiResult<Plug[]>>(
SERVER_API_URL + '/system/plug/ranking',
{
params
}
);
if (res.data.code === 0 && res.data.data) {
return res.data.data;
}
return Promise.reject(new Error(res.data.message));
}
/**
* 检查IP是否存在
*/
export async function checkExistence(
field: string,
value: string,
id?: number
) {
const res = await request.get<ApiResult<unknown>>(
SERVER_API_URL + '/system/plug/existence',
{
params: { field, value, id }
}
);
if (res.data.code === 0) {
return res.data.message;
}
return Promise.reject(new Error(res.data.message));
}
// 搜索历史
export async function searchHistory(params?: String) {
const res = await request.get<ApiResult<String[]>>(
SERVER_API_URL + '/system/plug/search-history',
{
params
}
);
if (res.data.code === 0 && res.data.data) {
return res.data.data;
}
return Promise.reject(new Error(res.data.message));
}
/**
* 制作插件
*/
export async function createPlug(data: Plug) {
const res = await request.post<ApiResult<unknown>>(
SERVER_API_URL + '/system/plug/plug',
data
);
if (res.data.code === 0) {
return res.data.message;
}
return Promise.reject(new Error(res.data.message));
}

View File

@@ -0,0 +1,67 @@
import type { PageParam } from '@/api';
/**
* 插件
*/
export interface Plug {
plugId?: number;
plugName?: string;
plugCode?: string;
// 菜单id
menuId?: number;
// 上级id, 0是顶级
parentId?: number;
// 菜单名称
title?: string;
// 菜单路由地址
path?: string;
// 菜单组件地址
component?: string;
// 菜单类型, 0菜单, 1按钮
menuType?: number;
// 排序号
sortNumber?: number;
// 权限标识
authority?: string;
// 菜单图标
icon?: string;
// 是否隐藏, 0否,1是(仅注册路由不显示左侧菜单)
hide?: number;
// 路由元信息
meta?: string;
score?: number;
price?: number;
// 创建时间
createTime?: string;
// 子菜单
children?: Plug[];
// 权限树回显选中状态, 0未选中, 1选中
checked?: boolean;
shortName?: string;
comments?: string;
content?: string;
//
key?: number;
//
value?: number;
//
parentIds?: number[];
//
openType?: number;
//
userId?: number;
//
appId?: number;
status?: number;
tenantId?: number;
}
/**
* 插件搜索条件
*/
export interface PlugParam extends PageParam {
title?: string;
path?: string;
authority?: string;
parentId?: number;
}