/ac-selector

react component

Primary LanguageJavaScriptMIT LicenseMIT

ac-selector

npm version

简介

用友业务中台选人组件

peerDependencies

  • react
  • react-dom
  • prop-types

INSTALL

  npm i ac-selector

EXAMPLE

	import Selector from 'ac-selector'
	import 'ac-selector/build/Selector.css'
	class Example extends React.Component {
		render {
			return (
				<Selector 
					show={控制模态框状态}
					onConfirm={确认按钮回调函数}
					onClose={关闭模态框回调函数}
				/>
			)
		}
	} 

API

参数 说明 类型 是否必填 默认值 返回值
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 自定义展示规则列表,不传的话需要传documentNodocumentName,否则规则没有数据
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中全部返回

关于扩展的详细可参考 demo2

demo2

部分数据的格式

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'
        }
      ]
    }
  ]

onConfirm回调函数参数说明

  • 参数一(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: '规则名称',
		...{其他用户自定义的属性}
  }