用友业务中台选人组件
react
react-dom
prop-types
npm i ac-selector
import Selector from 'ac-selector'
import 'ac-selector/build/Selector.css'
class Example extends React.Component {
render {
return (
<Selector
show={控制模态框状态}
onConfirm={确认按钮回调函数}
onClose={关闭模态框回调函数}
/>
)
}
}
参数 | 说明 | 类型 | 是否必填 | 默认值 | 返回值 |
---|---|---|---|---|---|
show |
是否显示模态框 | boolean |
是 | false |
无 |
locale |
语言显示 | string |
是 | zh_CN (可选zh_TW ,en_US ) |
无 |
onConfirm |
确认回调函数 | func |
是 | () => {} |
选中的用户 |
onClose |
取消回调函数 | func |
是 | () => {} |
无 |
selectedUser |
已选的用户列表 | array |
否 | [] |
无 |
selectedOther |
已选的其他列表 |
array |
否 | [] |
无 |
mode |
环境区分 | string |
否 | daily |
|
documentNo |
单据编号 | string |
否 | st_purchaseorder |
规则选人查询数据必传参数 |
documentName |
单据名称 | string |
否 | 无 | 规则选人根节点展示的名称 |
ruleList |
规则列表 | array |
否 | 无 | 自定义展示规则列表,不传的话需要传documentNo 和documentName ,否则规则没有数据 |
tabHandleFunc |
扩展标签点击时候的回调,传参数(tabMark, index, e) | func |
否 | 无 | 无 |
tabConfig |
传入的扩展数据(字段在下面示例代码) | array |
否 | [] | 无 |
tableData |
传入的列表(字段在下面示例代码) | array |
否 | [] | 无 |
treeConfig |
传入的树(字段在下面示例代码) | array |
否 | [] | 无 |
pageTotal |
分页,总共条数 | number |
否 | 无 | 无 |
pageItems |
分页,总页数 | number |
否 | 无 | 无 |
mode
用来指定请求接口请求什么环境,可选值为
{
dev: '测试环境',
daily: '日常环境',
pre: '预发布',
diwork: 'diwork ys融合环境',
diwork-prod: '生产'
}
默认是daily
环境
当使用ruleList
时,可能会希望自定义的属性在确认的回调函数里面也可以被返回以做后续的逻辑处理。自定义的属性可以任意,但不能是key
type
typCode
ruleCode
ruleName
reciving
,这些字段的值会被覆盖
假如自定义的ruleList的结构是这样
[
{
id: '1111',
name: '1111',
attrs: [
{
id: '1-1',
reciverType: '4444',
name: '1-1aaa'
}
]
}
]
那么id reciverType name 这三个字段会在otherList中全部返回
tabConfig = [
{
// 自定义标签名称
tabName: '扩展名',
// 自定义标签唯一标识,请不要使用特殊符号,以字母开头
tabMark: 'extend',
// 选项卡对应的类型,table/tree
tabType: 'table',
// table 对应的配置,若 tabType 非 table,可缺省
tableConfig: {
// 搜索框的laceholder
searchPlaceholder: '请输入您要查找的XX',
// 回车搜索的回调
enterSearchFunc: this.enterSearchFunc,
// 点击搜索按钮时候的回调
clickSearchFunc: this.clickSearchFunc,
// tabHandleFunc: this.tabHandleFunc,
// 列表表头配置,详情见 tinper-bee的 MultiSelectTable组件
tableColumns: [
{ key: 'username', title: '姓名', dataIndex: 'username', width: 100 },
{ key: 'orgName', title: '部门', dataIndex: 'orgName', width: 200 },
{ key: 'email', title: '账号(邮箱)', dataIndex: 'email', width: 200 },
{ key: 'mobile', title: '手机号码', dataIndex: 'mobile', width: 150 }
]
}
},
{
tabName: '扩展2',
tabMark: 'extend2',
tabType: 'tree',
// tree 对应的配置,若 tabType 非 tree,可缺省
treeConfig: [
{
// id
orgId: '1440500105089280',
// 显示名称
orgName: '北京用友实业公司',
// 父级id
parentId: '',
childs: [
{
orgId: '1440592889499904',
orgName: '仓储中心-北京',
parentId: '1440500105089280',
childs: [
{
orgId: '1492929388744960',
orgName: '新增',
parentId: '1440592889499904'
}
]
},
{
orgId: '1440592918794496',
orgName: '仓储中心-南京',
parentId: '1440500105089280'
}
]
}
]
}
]
tableData = {
// 列表数据
tableData: [
{
// 必要保留字段,与自定义标签相同,用来展示 其他列表 中的 '类型' 信息
type: '扩展名',
// 必要保留字段,唯一标识
key: '1',
roleId: '1',
// 必要保留字段,用来展示 其他列表 中的 '接受对象' 信息
reciving: 'name1',
username: 'name1',
orgName: 'orgName1',
email: 'yonyou@yonyou.com',
mobile: '123456'
},
{
type: '扩展名',
key: '2',
roleId: '2',
reciving: 'name2',
username: 'name2',
orgName: 'orgName2',
email: 'yonyou@yonyou.com',
mobile: '123456'
}
]
}
treeConfig= [
{
// 与扩展的标签相同
type:'扩展2',
// 与id相同,
orgId: '1440500105089280',
// 显示名称
orgName: '北京用友实业公司',
parentId: '',
childs: [
{
type:'扩展2',
orgId: '1440592889499904',
orgName: '仓储中心-北京',
parentId: '1440500105089280',
childs: [
{
type:'扩展2',
orgId: '1492929388744960',
orgName: '新增',
parentId: '1440592889499904'
}
]
},
{
type:'扩展2',
orgId: '1440592918794496',
orgName: '仓储中心-南京',
parentId: '1440500105089280'
}
]
}
]
- 参数一(userList)数据结构 选择的用户
{
type:'用户',
typeCode: 0,
userid:'用户id',
username:'用户名',
mobile:'手机号',
email:'用户邮箱',
orgName:'用户部门',
}
- 参数二(otherList)数据结构
角色
{
type: '角色',
typeCode: 1,
roleId: '角色id',
roleCode: '角色code',
roleName: '角色名称'
}
组织
{
type: '组织',
typeCode: 2,
orgId: '组织ID',
orgName: '组织名称'
}
规则
{
type: '规则',
typeCode: 3,
ruleCode: '规则code',
ruleName: '规则名称',
...{其他用户自定义的属性}
}