mirror of
https://github.com/certd/certd.git
synced 2026-05-16 13:17:29 +08:00
6ec697b010
refactor: 1.11.0 refactor: 1.11.0 refactor: 1.11.0 refactor: 1.11.0 refactor: ts化 refactor: ts化 feat: 全面TS化 perf: 全面ts化 refactor: 继续优化ts perf: ts定义优化 fix: 修复wangeditor无法上传视频的bug
331 lines
9.8 KiB
TypeScript
331 lines
9.8 KiB
TypeScript
import * as api from "./api";
|
|
import { requestForMock } from "/src/api/service";
|
|
import { AddReq, CreateCrudOptionsProps, CreateCrudOptionsRet, DelReq, dict, DictOnReadyContext, EditReq, UserPageQuery, UserPageRes } from "@fast-crud/fast-crud";
|
|
import { ref } from "vue";
|
|
import _ from "lodash-es";
|
|
function useSearchRemote() {
|
|
let lastFetchId = 0;
|
|
|
|
const state = {
|
|
data: ref([]),
|
|
fetching: ref(false)
|
|
};
|
|
const fetchUser = _.debounce((value) => {
|
|
console.log("fetching user", value);
|
|
lastFetchId += 1;
|
|
|
|
const fetchId = lastFetchId;
|
|
|
|
state.data.value = [];
|
|
|
|
state.fetching.value = true;
|
|
|
|
fetch("https://randomuser.me/api/?results=5")
|
|
.then((response) => response.json())
|
|
.then((body) => {
|
|
if (fetchId !== lastFetchId) {
|
|
// for fetch callback order
|
|
return;
|
|
}
|
|
const data = body.results.map((user: any) => ({
|
|
text: `${user.name.first} ${user.name.last}`,
|
|
value: user.login.username
|
|
}));
|
|
state.data.value = data;
|
|
state.fetching.value = false;
|
|
});
|
|
}, 800);
|
|
|
|
return {
|
|
fetchUser,
|
|
searchState: state
|
|
};
|
|
}
|
|
export default function ({ crudExpose }: CreateCrudOptionsProps): CreateCrudOptionsRet {
|
|
const pageRequest = async (query: UserPageQuery): Promise<UserPageRes> => {
|
|
return await api.GetList(query);
|
|
};
|
|
const editRequest = async ({ form, row }: EditReq) => {
|
|
form.id = row.id;
|
|
return await api.UpdateObj(form);
|
|
};
|
|
const delRequest = async ({ row }: DelReq) => {
|
|
return await api.DelObj(row.id);
|
|
};
|
|
|
|
const addRequest = async ({ form }: AddReq) => {
|
|
return await api.AddObj(form);
|
|
};
|
|
|
|
const dictRef = dict({
|
|
value: "id",
|
|
label: "text",
|
|
data: [
|
|
{ id: "sz", text: "深圳", color: "success" },
|
|
{ id: "gz", text: "广州", color: "blue" },
|
|
{ id: "bj", text: "北京" },
|
|
{ id: "wh", text: "武汉" },
|
|
{ id: "sh", text: "上海" }
|
|
]
|
|
});
|
|
|
|
function dynamicUpdateDictOptions() {
|
|
dictRef.data.push({ id: "xg", text: "香港" });
|
|
//dictRef.toMap();
|
|
}
|
|
|
|
const { fetchUser, searchState } = useSearchRemote();
|
|
return {
|
|
dynamicUpdateDictOptions,
|
|
crudOptions: {
|
|
request: {
|
|
pageRequest,
|
|
addRequest,
|
|
editRequest,
|
|
delRequest
|
|
},
|
|
form: {
|
|
// 单列布局
|
|
col: { span: 24 },
|
|
labelCol: { span: 4 },
|
|
wrapperCol: { span: 18 }
|
|
},
|
|
rowHandle: {
|
|
fixed: "right",
|
|
align: "center"
|
|
},
|
|
table: {
|
|
scroll: {
|
|
//启用横向滚动条,设置一个大于所有列宽之和的值,一般大于表格宽度
|
|
x: 1400
|
|
}
|
|
},
|
|
columns: {
|
|
id: {
|
|
title: "ID",
|
|
key: "id",
|
|
type: "number",
|
|
column: {
|
|
width: 50
|
|
},
|
|
form: {
|
|
show: false
|
|
}
|
|
},
|
|
statusLocal: {
|
|
title: "单选本地",
|
|
type: "dict-select",
|
|
dict: dictRef
|
|
},
|
|
statusRemote: {
|
|
title: "单选远程",
|
|
search: {
|
|
show: true,
|
|
rules: null,
|
|
component: {
|
|
style: { width: "100px" }
|
|
}
|
|
},
|
|
type: "dict-select",
|
|
dict: dict({
|
|
url: "/mock/dicts/OpenStatusEnum?simple"
|
|
}),
|
|
form: {
|
|
rules: [{ required: true, message: "请选择一个选项" }]
|
|
}
|
|
},
|
|
filter: {
|
|
title: "本地过滤",
|
|
type: "dict-select",
|
|
dict: dict({
|
|
url: "/mock/dicts/OpenStatusEnum?simple"
|
|
}),
|
|
form: {
|
|
component: {
|
|
showSearch: true,
|
|
//默认的filterOption仅支持value的过滤,label并不会加入查询
|
|
//所以需要自定义filterOption
|
|
filterOption(inputValue: any, option: any) {
|
|
return option.label.indexOf(inputValue) >= 0 || option.value.indexOf(inputValue) >= 0;
|
|
}
|
|
}
|
|
}
|
|
},
|
|
search: {
|
|
title: "远程搜索",
|
|
type: "text",
|
|
search: { show: true, component: { style: { width: "240px" } } },
|
|
form: {
|
|
component: {
|
|
name: "a-select",
|
|
vModel: "value",
|
|
filterOption: false,
|
|
//labelInValue: true,
|
|
mode: "multiple",
|
|
showSearch: true,
|
|
allowClear: true,
|
|
placeholder: "输入远程搜索,数据仅供演示",
|
|
options: searchState.data,
|
|
onSearch(value: any) {
|
|
fetchUser(value);
|
|
},
|
|
children: {
|
|
notFoundContent() {
|
|
if (searchState.fetching.value) {
|
|
return <a-spin size="small" />;
|
|
}
|
|
return "暂无记录";
|
|
}
|
|
}
|
|
}
|
|
}
|
|
},
|
|
customDictGetData: {
|
|
title: "自定义字典请求",
|
|
search: { show: false },
|
|
type: "dict-select",
|
|
dict: dict({
|
|
getData({ dict }) {
|
|
// 覆盖全局获取字典请求配置
|
|
console.log(`我是从自定义的getData方法中加载的数据字典`, dict);
|
|
return requestForMock({
|
|
url: "/mock/dicts/OpenStatusEnum?cache",
|
|
method: "get"
|
|
});
|
|
}
|
|
}),
|
|
form: {
|
|
value: "2", //默认值, 注意search也会影响到,需要将search.value=null,取消search的默认值
|
|
helper: "dict.getData可以覆盖全局配置的getRemoteDictFunc"
|
|
},
|
|
column: {
|
|
width: 120,
|
|
component: {
|
|
type: "text" // 不使用tag,纯文本展示
|
|
}
|
|
}
|
|
},
|
|
disabledOptions: {
|
|
title: "禁用某个选项",
|
|
type: "dict-select",
|
|
dict: dict({
|
|
url: "/mock/dicts/OpenStatusEnum?disabledOptions"
|
|
}),
|
|
form: {
|
|
component: {
|
|
dict: {
|
|
// 此处dict配置会覆盖上面dict的属性
|
|
prototype: true, // form表单的dict设置为原型复制,每次初始化时都会重新loadDict
|
|
onReady({ dict }: DictOnReadyContext) {
|
|
console.log("字典请求ready", dict);
|
|
dict.data[0].disabled = true; // 禁用某个选项, 还可以自己修改选项
|
|
}
|
|
}
|
|
},
|
|
helper: "禁用字典选项"
|
|
},
|
|
column: {
|
|
width: 150
|
|
}
|
|
},
|
|
firstDefault: {
|
|
title: "默认值",
|
|
type: "dict-select",
|
|
dict: dict({
|
|
url: "/mock/dicts/OpenStatusEnum?disabledOptions"
|
|
}),
|
|
form: {
|
|
component: {
|
|
//监听 dict-change事件
|
|
onDictChange({ dict, form, key }: any) {
|
|
console.log("dict data changed", dict, key);
|
|
if (dict.data != null && form.firstDefault == null) {
|
|
form.firstDefault = dict.data[0].value;
|
|
}
|
|
}
|
|
// 下面的方法也可以,注意要配置dict.prototype:true
|
|
// dict: {
|
|
// // 此处dict配置会覆盖上面dict的属性
|
|
// // form表单的dict设置为原型复制,每次初始化时都会重新loadDict
|
|
// prototype: true,
|
|
//
|
|
// onReady({ dict, form }) {
|
|
// console.log("字典请求ready", dict, form, getComponentRef);
|
|
// // prototype= true 才能获取到form表单数据
|
|
// form.firstDefault = dict.data[0].value;
|
|
// }
|
|
// }
|
|
},
|
|
helper: "默认选择第一个选项"
|
|
}
|
|
},
|
|
multiple: {
|
|
title: "多选自动染色",
|
|
sortable: true,
|
|
type: "dict-select",
|
|
form: {
|
|
title: "多选本地",
|
|
component: {
|
|
mode: "multiple"
|
|
}
|
|
},
|
|
dict: dict({
|
|
data: [
|
|
{ value: "sz", label: "深圳", color: "success" },
|
|
{ value: "gz", label: "广州" },
|
|
{ value: "wh", label: "武汉" },
|
|
{ value: "sh", label: "上海" },
|
|
{ value: "hz", label: "杭州" },
|
|
{ value: "bj", label: "北京", color: "red" }
|
|
]
|
|
}),
|
|
column: {
|
|
width: 290,
|
|
component: {
|
|
color: "auto", // 自动染色
|
|
defaultLabel: "未知城市" //无数据字典时的默认文本
|
|
}
|
|
}
|
|
},
|
|
tags: {
|
|
title: "可输入",
|
|
sortable: true,
|
|
type: "dict-select",
|
|
form: {
|
|
component: {
|
|
mode: "tags"
|
|
}
|
|
},
|
|
dict: dict({
|
|
data: [
|
|
{ value: "sz", label: "深圳", color: "success" },
|
|
{ value: "gz", label: "广州" },
|
|
{ value: "wh", label: "武汉" },
|
|
{ value: "sh", label: "上海" },
|
|
{ value: "hz", label: "杭州" },
|
|
{ value: "bj", label: "北京", color: "red" }
|
|
]
|
|
})
|
|
},
|
|
statusSimple: {
|
|
title: "普通选择",
|
|
type: "text",
|
|
form: {
|
|
component: {
|
|
name: "a-select",
|
|
vModel: "value",
|
|
options: [
|
|
{ value: "sz", label: "深圳", color: "success" },
|
|
{ value: "gz", label: "广州", color: "blue" },
|
|
{ value: "bj", label: "北京" },
|
|
{ value: "wh", label: "武汉" },
|
|
{ value: "sh", label: "上海" }
|
|
]
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
};
|
|
}
|