forked from jiangxy/react-antd-admin
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathconfig.js
164 lines (137 loc) · 5.08 KB
/
config.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
/**
* 定义整个项目的全局配置
*/
'use strict';
// 约定优于配置
// 我可以提供尽量多的配置, 但尽量不要太个性化, 接口的路径/名称/格式之类的
// 遵循统一的规范, 好维护, 交给其他人也比较简单
module.exports = {
name: 'OOXX管理后台', // 项目的名字
favicon: 'http://jxy.me/favicon.ico', // 设置网页的favicon, 可以是外链, 也可以是本地
footer: '<a target="_blank" href="http://jxy.me">foolbear</a>版权所有 © 2015-2099', // footer中显示的字, 可以嵌入html标签
debug: true, // 是否开启debug模式, 不会请求后端接口, 使用mock的数据
tabMode: { // tab模式相关配置
enable: false, // 是否开启tab模式
allowDuplicate: false, // 同一个菜单项只允许一个tab
},
log: {
level: 'info', // 日志级别, 类似slf4j中的root logger, 目前支持debug/info/warn/error 4种级别
// 除了root logger以外, 也可以为每个logger单独设置级别
debug: [],
info: [],
warn: [],
error: ['loggerA', 'loggerB'], // 示例, 对于loggerA和loggerB使用error级别, 其他logger使用默认的info级别
},
api: { // 对后端请求的相关配置
host: 'http://localhost:12345', // 调用ajax接口的地址, 默认值空, 如果是跨域的, 服务端要支持CORS
path: '/api', // ajax请求的路径
timeout: 15000, // 请求的超时时间, 单位毫秒
},
login: { // 登录相关配置
getCurrentUser: '/getCurrentUser', // 后端必须要提供接口校验当前用户的身份, 如果拿不到用户信息, 才会尝试登录
// 登录有两种情况:
// 1. 使用sso登录, 直接跳转就可以了
sso: '', // 是否使用单点登录? 是的话我会把地址encode后加到后面, 然后跳转, 如果这个是空字符串, 说明不使用单点登录
// 2. 不使用sso, 使用我提供的一个登录界面
validate: '/login', // 校验用户信息, 表单的submit地址. 如果登录成功, 必须返回用户名
logout: '/logout', // 退出的url, 用户点击退出时, 浏览器会直接跳转到这个链接
},
upload: { // 上传相关配置
// 上传图片和上传普通文件分别配置
image: '/uploadImage', // 默认的上传图片接口
imageSizeLimit: 1500, // 默认的图片大小限制, 单位KB
file: '/uploadFile', // 默认的上传文件的接口
fileSizeLimit: 10240, // 默认的文件大小限制, 单位KB
},
sidebar: { // 侧边栏相关配置
collapsible: true, // 是否显示折叠侧边栏的按钮
autoMenuSwitch: true, // 只展开一个顶级菜单, 其他顶级菜单自动折叠
},
DBTable: { // DBTable组件相关配置
pageSize: 50, // 表格每页显示多少条数据
showSizeChanger: true, // 是否可以修改每页显示多少条数据
pageSizeOptions: ['10', '20', '50', '100'], // 指定每页可以显示多少条
default: { // 针对每个表格的默认配置
showExport: true, // 显示导出按钮, 默认true
showImport: true, // 显示导入按钮, 默认true
showInsert: true, // 显示新增按钮, 默认true
showUpdate: true, // 显示修改按钮, 默认true
showDelete: true, // 显示删除按钮, 默认true
asyncSchema: false, // 是否从服务端加载schema, 默认false
ignoreSchemaCache: false, // 是否忽略schema的缓存, 对于异步schema而言, 默认只会请求一次后端接口然后缓存起来
},
},
// 以下一些辅助的函数, 不要修改
// 不能使用箭头函数, 会导致this是undefined
/**
* 是否要跨域请求
*
* @returns {boolean}
*/
isCrossDomain() {
if (this.api.host && this.api.host !== '') {
return true;
} else {
return false;
}
},
/**
* 是否单点登录
*
* @returns {boolean}
*/
isSSO() {
if (this.login.sso && this.login.sso !== '') {
return true;
} else {
return false;
}
},
/**
* 获得api请求的路径
*
* @returns {*}
*/
getAPIPath() {
if (this.tmpApiPath) { // 缓存
return this.tmpApiPath;
}
const paths = [];
// js的字符串处理真是麻烦
if (this.isCrossDomain()) {
// 去除结尾的'/'
const tmp = this.api.host;
let index = tmp.length - 1;
// 如果超出指定的 index 范围,charAt返回一个空字符串
while (tmp.charAt(index) === '/') {
index--;
}
if (index < 0)
paths.push('');
else
paths.push(tmp.substring(0, index + 1));
} else {
paths.push('');
}
if (this.api.path) {
const tmp = this.api.path;
let begin = 0;
let end = tmp.length - 1;
while (tmp.charAt(begin) === '/') {
begin++;
}
while (tmp.charAt(end) === '/') {
end--;
}
if (begin > end)
paths.push('');
else
paths.push(tmp.substring(begin, end + 1));
} else {
paths.push('');
}
const tmpApiPath = paths.join('/');
this.tmpApiPath = tmpApiPath;
return tmpApiPath;
},
};