123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408 |
- /*
- * @Author: your name
- * @Date: 2021-07-26 10:13:13
- * @LastEditTime: 2022-02-28 16:14:22
- * @LastEditors: Please set LastEditors
- * @Description: In User Settings Edit
- * @FilePath: /TracerMethodology_PC/src/pages/UserMana/index.js
- */
- import { PlusOutlined } from '@ant-design/icons';
- import { Button, Popconfirm,Form} from 'antd';
- import React, { useState, useRef } from 'react';
- import { PageContainer } from '@ant-design/pro-layout';
- import ProTable from '@ant-design/pro-table';
- import { ModalForm, ProFormText,ProFormDateRangePicker } from '@ant-design/pro-form';
- import UpdateForm from './updateForm';
- import DrawerContent from './component/drawer';
- import { getRoleList, roleBindUser, addList, editList, delList,roleBindMenu,roleHasBindUsers,roleHasBindMenus } from './service';
- import { getUserList } from '@/pages/PlatformMana/userMana/service';
- import moment from 'moment';
- import 'moment/locale/zh-cn';
- import locale from 'antd/es/date-picker/locale/zh_CN';
- import { getMenuList } from '@/pages/PlatformMana/menuManage/service';
- import './style.less';
- const UserMana = () => {
- const columns = [
- {
- title: '角色名',
- dataIndex: 'roleName',
- key: 'roleName',
- },
- {
- title: '变更人',
- dataIndex: 'modifyUserName',
- key: 'modifyUserName',
- hideInSearch: true,
- },
- {
- title: '变更日期',
- dataIndex: 'modifyTime',
- key: 'modifyTime',
- renderFormItem: (item, { type, defaultRender, formItemProps, fieldProps, ...rest }, form) => {
- if (type === 'form') {
- return null;
- }
- return (
- <Form.Item noStyle>
- <ProFormDateRangePicker fieldProps={{locale,onChange:(moment)=>{console.log(moment)} }} name="modifyTime" />
- </Form.Item>
- )
- },
- },
- {
- title: '操作',
- dataIndex: 'option',
- valueType: 'option',
- render: (_, record) => [
- <a
- key="config"
- onClick={() => {
- bindInitHandle(record,'user');
- }}
- >
- 用户
- </a>,
- <a
- key="config"
- onClick={() => {
- bindInitHandle(record,'menu');
- }}
- >
- 权限
- </a>,
- <a
- key="config"
- onClick={() => {
- handleUpdateModalVisible(true);
- setCurrentRow(record);
- }}
- >
- 编辑
- </a>,
- <Popconfirm
- key="subscribeAlert"
- title="是否确定删除?"
- onConfirm={() => {
- delUserHandler(record);
- }}
- >
- <a>删除</a>
- </Popconfirm>,
- ],
- },
- ];
- const DrawerTableUsersColumns = [
- {
- title: 'Id',
- dataIndex: 'id',
- key: 'id',
- hideInSearch: true,
- },
- {
- title: '姓名',
- dataIndex: 'name',
- key: 'name',
- },
- {
- title: '用户名',
- dataIndex: 'account',
- key: 'account',
- hideInSearch: true,
- },
- {
- title: '在职状态',
- dataIndex: 'hospitalStatus',
- key: 'hospitalStatus',
- hideInSearch: true,
- render:num=><>{num==0?'离职':'在职'}</>
- },
- ];
-
- const DrawerTableMenusColumns = [
- {
- title: 'Id',
- dataIndex: 'menuId',
- key: 'menuId',
- hideInSearch: true,
- },
- {
- title: '菜单名称',
- dataIndex: 'name',
- key: 'name',
- }
- ];
- const [createModalVisible, handleModalVisible] = useState(false);
- const [updateModalVisible, handleUpdateModalVisible] = useState(false);
- const actionRef = useRef();
- const [currentRow, setCurrentRow] = useState({});
- const [editRoleBindUsers, setEditRoleBindUsers] = useState(false);
- const [drawerVisible, setDrawerVisible] = useState(false);
- const [selectedUsers,setSelectedUsers] = useState([]);
- const [selectedMenus,setSelectedMenus] = useState([]);
- // const [shareParamsSetting,setShareParamsSetting] = useState(false); //是否分摊参数设置
- /**
- *
- * @param {Boolean} bool 弹窗展示状态
- */
- const updateModalVisibleChange = (bool) => {
- handleUpdateModalVisible(bool);
- if (!bool) setCurrentRow(undefined);
- };
- // 获取列表
- const getList = async (params = {}, sort, filter) => {
- // format: (value) => { return [value[0].format('YYYY-MM-DD'),value[1].format('YYYY-MM-DD')] }
- const {pageSize,current,modifyTime,roleName:keyword} = params;
- const query = modifyTime?{pageSize,current,keyword,startDate:moment(modifyTime[0]).format('YYYY-MM-DD'),endDate:moment(modifyTime[1]).format('YYYY-MM-DD')}:{pageSize,current,keyword}
- const res = await getRoleList(query);
- if(res){
- return {
- data: res.list,
- total: res.totalCount,
- success:true,
- };
- }
- };
- // 获取Drawer用户列表
- const getUsers = async (params = {}, sort, filter) => {
- const {roleId} = currentRow;
- const resp = await roleHasBindUsers({roleId});
- if(resp){
- const tempArr = resp.map(item=>item.id);
- setSelectedUsers(tempArr);
- }
- const res = await getUserList({...params,roleId:currentRow.roleId});
- if(res){
- return {
- data: res.list,
- total: res.totalCount,
- success: true,
- };
- }
- };
- // 获取Drawer菜单列表
- const getMenus = async (params = {}, sort, filter) => {
- const res = await getMenuList(params);
- if(res){
- return {
- data: res.list,
- total: res.totalCount,
- success:true,
- };
- }
- };
- /**
- *
- * @param {Object} value 删除项数据
- */
- const delUserHandler = async (value) => {
- const ids = [value.roleId];
- const resp = await delList({ ids });
- if (resp) {
- if (actionRef.current) {
- actionRef.current.reload();
- }
- }
- };
-
- // 绑定初始化
- /**
- *
- * @param {Object} record
- * @param {String} type user/menu
- */
- const bindInitHandle = async (record,type)=>{
-
- const {roleId} = record;
- setCurrentRow(record);
- if(type == 'user'){
- const resp = await roleHasBindUsers({roleId});
- if(resp){
- const tempArr = resp.map(item=>item.id);
- setSelectedUsers(tempArr);
- }
- setEditRoleBindUsers(true);
- }
-
- if(type == 'menu'){
- const resp = await roleHasBindMenus({roleId});
- if(resp){
- const tempArr = resp.map(item=>item.id);
- setSelectedMenus(tempArr);
- }
- setEditRoleBindUsers(false);
- }
- setDrawerVisible(true);
- setCurrentRow(record);
- }
- return (
- <PageContainer>
- <ProTable
- columns={columns}
- request={getList}
- actionRef={actionRef}
- rowKey="roleId"
- toolBarRender={() => [
- <Button
- key="button"
- icon={<PlusOutlined />}
- type="primary"
- onClick={() => {
- handleModalVisible(true);
- }}
- >
- 新增
- </Button>,
- ]}
- pagination={{
- pageSize: 10,
- }}
- />
- <ModalForm
- title="新增角色"
- width="800px"
- labelCol={{ span: 5, offset: 3 }}
- layout={'horizontal'}
- visible={createModalVisible}
- onVisibleChange={handleModalVisible}
- modalProps={{
- destroyOnClose:true
- }}
- onFinish={async (value) => {
- const success = await addList(value);
- // console.log({ success });
- if (success) {
- handleModalVisible(false);
- if (actionRef.current) {
- actionRef.current.reload();
- }
- }
- return true;
- }}
- >
- <ProFormText
- label="角色名"
- rules={[
- {
- required: true,
- message: '角色名是必填项!',
- },
- ]}
- width="sm"
- name="roleName"
- />
- <ProFormText
- label="备注"
- rules={[
- {
- required: false,
- message: '',
- },
- ]}
- width="sm"
- name="remark"
- />
- </ModalForm>
- {/* 更新 */}
- <UpdateForm
- onSubmit={async (value) => {
- // console.log({value});
- const { roleId, roleName, remark } = value;
- const success = await editList({ roleId, roleName, remark });
- if (success) {
- handleUpdateModalVisible(false);
- setCurrentRow(undefined);
- if (actionRef.current) {
- actionRef.current.reload();
- }
- }
-
- }}
- onCancel={() => {
- handleUpdateModalVisible(false);
- setCurrentRow(undefined);
- }}
- updateModalVisible={updateModalVisible}
- updateModalVisibleChange={updateModalVisibleChange}
- values={currentRow || {}}
- />
- {editRoleBindUsers ? (
- // 编辑用户
- <DrawerContent
- columns={DrawerTableUsersColumns}
- visible={drawerVisible}
- currentRow={currentRow}
- title="绑定用户"
- defaultSelected={selectedUsers}
- onVisibleChange={(bool) => setDrawerVisible(bool)}
- renderListFunc={getUsers}
- config={{tableSearch:true}}
- onFinishFunc={async (value, selectedRowKeys) => {
-
- const { roleId } = currentRow;
- const resp = await roleBindUser({ roleId, userIds: selectedRowKeys });
- const { status } = resp;
- if (status == 200) {
- setDrawerVisible(false);
- setCurrentRow(undefined);
- if (actionRef.current) {
- actionRef.current.reload();
- }
- }
- }}
- />
- ) : (
- // 编辑权限
- <DrawerContent
- columns={DrawerTableMenusColumns}
- visible={drawerVisible}
- currentRow={currentRow}
- title="绑定权限"
- defaultSelected={selectedMenus}
- onVisibleChange={(bool) => setDrawerVisible(bool)}
- renderListFunc={getMenus}
- config={{rowKeys:'menuId',tableSearch:false}}
- tableSearch={false}
- onFinishFunc={async (value, selectedRowKeys) => {
- const { roleId } = currentRow;
- const resp = await roleBindMenu({ roleId, menuIds: selectedRowKeys });
- const { status } = resp;
- if (status == 200) {
- setDrawerVisible(false);
- setCurrentRow(undefined);
- if (actionRef.current) {
- actionRef.current.reload();
- }
- }
- }}
- />
- )}
- </PageContainer>
- );
- };
- export default UserMana;
|