Browse Source

(+)权限绑定角色

master
ww664853070 2 years ago
parent
commit
9b48860250
  1. 25
      api/app/lib/controllers/resource/index.js
  2. 52
      api/app/lib/controllers/roleResource/index.js
  3. 11
      api/app/lib/routes/resource/index.js
  4. 14
      api/app/lib/routes/roleResource/index.js
  5. 6
      doc/scripts/tools/v3.22.1_init_HRM_resource/config.js
  6. 37
      web/client/src/sections/humanAffairs/actions/role.js
  7. 194
      web/client/src/sections/humanAffairs/containers/employeeAuth.jsx
  8. 3
      web/client/src/utils/webapi.js

25
api/app/lib/controllers/resource/index.js

@ -0,0 +1,25 @@
'use strict';
const moment = require('moment')
const fs = require('fs');
async function get(ctx) {
try {
const { models } = ctx.fs.dc;
let resourceList = await models.Resource.findAndCountAll({
order: [['id']],
});
ctx.status = 200
ctx.body = resourceList;
} catch (error) {
ctx.fs.logger.error(`path:${ctx.path},error:${error}`)
ctx.status = 400;
ctx.body = { name: 'FindError', message: '权限列表' }
}
}
module.exports = {
get,
}

52
api/app/lib/controllers/roleResource/index.js

@ -0,0 +1,52 @@
'use strict';
const moment = require('moment')
const fs = require('fs');
async function get(ctx) {
try {
const { models } = ctx.fs.dc;
const { id } = ctx.request.query
let roleResourceList = await models.RoleResource.findAndCountAll({
order: [['id', 'desc']],
where: { roleId: id }
});
ctx.status = 200
ctx.body = roleResourceList;
} catch (error) {
ctx.fs.logger.error(`path:${ctx.path},error:${error}`)
ctx.status = 400;
ctx.body = { name: 'FindError', message: '查询角色绑定权限列表' }
}
}
async function add(ctx) {
try {
const { models } = ctx.fs.dc;
const { roleId, resourceId } = ctx.request.body
await models.RoleResource.destroy({
where: { roleId: roleId }
})
let storageData = resourceId.map(e => {
return {
roleId: roleId,
resId: e
}
})
await models.RoleResource.bulkCreate(storageData);
ctx.status = 204;
} catch (error) {
ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`);
ctx.status = 400;
ctx.body = {
message: typeof error == 'string' ? error : undefined
}
}
}
module.exports = {
get,
add,
}

11
api/app/lib/routes/resource/index.js

@ -0,0 +1,11 @@
'use strict';
const resource = require('../../controllers/resource');
module.exports = function (app, router, opts) {
app.fs.api.logAttr['GET/resource/list'] = { content: '查询角色列表', visible: true };
router.get('/resource/list', resource.get);
};

14
api/app/lib/routes/roleResource/index.js

@ -0,0 +1,14 @@
'use strict';
const roleResource = require('../../controllers/roleResource');
module.exports = function (app, router, opts) {
app.fs.api.logAttr['GET/roleResourcer/list'] = { content: '角色权限列表', visible: true };
router.get('/roleResource/list', roleResource.get);
app.fs.api.logAttr['POST/roleResource/add'] = { content: '角色添加权限成功', visible: true };
router.post('/roleResource/add', roleResource.add);
};

6
doc/scripts/tools/v3.22.1_init_HRM_resource/config.js

@ -14,9 +14,9 @@ const ENV_CS_POOL = { //生产环境数据库配置
} }
const PRO_POOL = { //研发自测用 const PRO_POOL = { //研发自测用
user: 'postgres', user: 'postgres',
host: '10.8.30.166', host: '10.8.16.184',
database: 'hr-dev', database: 'HRM',
password: '123', password: '123456',
port: 5432 port: 5432
} }
module.exports = { module.exports = {

37
web/client/src/sections/humanAffairs/actions/role.js

@ -80,3 +80,40 @@ export function addUserRole(data) {
msg: { option: '角色绑定用户' }, msg: { option: '角色绑定用户' },
}); });
} }
export function getResource(query) {//查询
return (dispatch) => basicAction({
type: "get",
dispatch: dispatch,
actionType: "GET_RESOURCE_LIST",
query: query,
url: `${ApiTable.getResource}`,
msg: { option: "查询权限列表列表" },
reducer: { name: "resourceList", params: { noClear: true } },
});
}
export function getRoleResource(query) {//查询
return (dispatch) => basicAction({
type: "get",
dispatch: dispatch,
actionType: "GET_ROLE_RESOURCE_LIST",
query: query,
url: `${ApiTable.getRoleResource}`,
msg: { option: "查询角色权限列表" },
reducer: { name: "roleResourceList", params: { noClear: true } },
});
}
export function addRoleResource(data) {
return dispatch => basicAction({
type: 'post',
dispatch: dispatch,
actionType: 'ADD_ROLE_RESOURCE',
url: ApiTable.addRoleResource,
data: data,
msg: { option: '角色绑定权限' },
});
}

194
web/client/src/sections/humanAffairs/containers/employeeAuth.jsx

@ -1,17 +1,17 @@
import React, { useEffect, useState, useRef } from 'react'; import React, { useEffect, useState, useRef } from 'react';
import { connect } from 'react-redux'; import { connect } from 'react-redux';
import { Col, Row, Button, Tree, ButtonGroup, RadioGroup, Radio, Checkbox, CheckboxGroup, Popconfirm, Modal, Form, useFormApi } from '@douyinfe/semi-ui'; import { Col, Row, Button, Tree, ButtonGroup, RadioGroup, Radio, Checkbox, CheckboxGroup, Popconfirm, Toast } from '@douyinfe/semi-ui';
import EmployeeAuthModal from './employeeAuthModal' import EmployeeAuthModal from './employeeAuthModal'
import EmployeeAuthUserModal from './employeeAuthUserModal' import EmployeeAuthUserModal from './employeeAuthUserModal'
import '../style.less' import '../style.less'
const EmployeeAuth = (props) => { const EmployeeAuth = (props) => {
const form = useRef(); const form = useRef();
const { dispatch, actions, roleList, userRoleList } = props const { dispatch, actions, roleList, userRoleList, resourceList } = props
const [dataRange, setDataRange] = useState(1); const [dataRange, setDataRange] = useState(1);
const [checkedList, setCheckedList] = useState([]); const [checkedList, setCheckedList] = useState([]);
const [indeterminate, setIndeterminate] = useState(true); const [roleId, setRoleId] = useState();
const [checkAll, setCheckall] = useState(false); const [two, setTwo] = useState({});
const [visible, setVisible] = useState(false); const [visible, setVisible] = useState(false);
const [eidtRole, setEidtRole] = useState(null); const [eidtRole, setEidtRole] = useState(null);
const [eidtTit, setEidtTit] = useState(null); const [eidtTit, setEidtTit] = useState(null);
@ -22,11 +22,13 @@ const EmployeeAuth = (props) => {
} }
useEffect(() => { useEffect(() => {
getRoleList() getRoleList()
dispatch(actions.humanAffairs.getResource())
}, []) }, [])
let hrUser = JSON.parse(sessionStorage.getItem('hrUser')) let hrUser = JSON.parse(sessionStorage.getItem('hrUser'))
console.log(hrUser, '登录返回'); console.log(hrUser, '登录返回');
console.log(roleList, '角色列表'); console.log(roleList, '角色列表');
console.log(userRoleList, '用户角色关联'); console.log(userRoleList, '用户角色关联');
console.log(resourceList, '权限列表');
const button = ( const button = (
<ButtonGroup <ButtonGroup
size="small" size="small"
@ -71,7 +73,7 @@ const EmployeeAuth = (props) => {
size="small" size="small"
theme="borderless" theme="borderless"
> >
<Button>删除</Button> {/* <Button>删除</Button> */}
</ButtonGroup> </ButtonGroup>
</div> </div>
), ),
@ -83,7 +85,7 @@ const EmployeeAuth = (props) => {
} }
roleLists.push({ roleLists.push({
label: ( label: (
<div style={style}> <div style={style} onClick={() => { roleListBtn(e.id) }}>
<span>{e.name}</span> <span>{e.name}</span>
<ButtonGroup <ButtonGroup
size="small" size="small"
@ -109,45 +111,93 @@ const EmployeeAuth = (props) => {
const dataRangeChange = (e) => { const dataRangeChange = (e) => {
setDataRange(e.target.value); setDataRange(e.target.value);
}; };
const plainOptions = [ const treeList = []
{ if (resourceList && resourceList.rows) {
id: 1, resourceList.rows.forEach((item) => {
name: '绩效考核', item.child = resourceList.rows.filter((sec) => {
child: [ return sec.parentId === item.id
{ id: 1, name: '基本动作', child: [{ id: 1, name: '查看' }, { id: 2, name: '添加' }, { id: 3, name: '编辑' }, { id: 4, name: '删除' }] }, })
{ id: 2, name: '员工考核', child: [{ id: 5, name: '查看' }, { id: 6, name: '添加' }, { id: 7, name: '编辑' }, { id: 8, name: '删除' }] }, if (item.parentId === null) {
{ id: 1, name: '中层考核', child: [{ id: 1, name: '查看' }, { id: 2, name: '添加' }, { id: 3, name: '编辑' }, { id: 4, name: '删除' }] }, treeList.push(item)
{ id: 2, name: '高管考核', child: [{ id: 5, name: '查看' }, { id: 6, name: '添加' }, { id: 7, name: '编辑' }, { id: 8, name: '删除' }] }, }
{ id: 1, name: '员工绩效', child: [{ id: 1, name: '查看' }, { id: 2, name: '添加' }, { id: 3, name: '编辑' }, { id: 4, name: '删除' }] }, })
] }
}, const onChangeOne = (value, recod) => {
{ let twos = two
id: 2, let selList = []
name: '模块2', recod.child.forEach(e => {
child: [ if (value.target.checked) {
{ id: 1, name: '模块2子模块1', child: [{ id: 1, name: '查看' }, { id: 2, name: '添加' }, { id: 3, name: '编辑' }, { id: 4, name: '删除' }] }, twos[e.id] = true
{ id: 2, name: '模块2子模块2', child: [{ id: 1, name: '查看' }, { id: 2, name: '添加' }, { id: 3, name: '编辑' }, { id: 4, name: '删除' }] } } else {
] twos[e.id] = false
}, }
{ if (e.child.length) {
id: 3, e.child.forEach(i => {
name: '模块3', selList.push(i.id)
child: [ })
{ id: 1, name: '模块3子模块1', child: [{ id: 1, name: '查看' }, { id: 2, name: '添加' }, { id: 3, name: '编辑' }, { id: 4, name: '导入' }] }, }
{ id: 2, name: '模块3子模块2', child: [{ id: 1, name: '查看' }, { id: 2, name: '添加' }, { id: 3, name: '编辑' }, { id: 4, name: '导出' }] } })
] if (value.target.checked) {
}, twos[value.target.value] = true
]; setTwo(twos)
const onCheckAllChange = (e) => { setCheckedList([...checkedList, ...selList])
setCheckedList(e.target.checked ? plainOptions : []); } else {
setIndeterminate(false); twos[value.target.value] = false
setCheckall(e.target.checked); setCheckedList(getDiffer(checkedList, selList));
}; setTwo(twos)
const onChange = (checkedList) => { }
setCheckedList(checkedList); }
setIndeterminate(!!checkedList.length && checkedList.length < plainOptions.length); console.log(treeList, '权限树形结构')
setCheckall(checkedList.length === plainOptions.length); const onCheckAllChange = (value, recod) => {
console.log(value.target, '第二阶', recod);
let selList = []
recod.child.forEach(i => {
if (i.id == value.target.value) {
if (i.child.length) {
i.child.forEach(s => {
selList.push(s.id)
})
}
}
})
let twos = two
if (value.target.checked) {
setCheckedList([...checkedList, ...selList])
twos[value.target.value] = true
twos[recod.id] = true
setTwo(two)
} else {
setCheckedList(getDiffer(checkedList, selList));
twos[value.target.value] = false
setTwo(two)
}
}; };
const checkItem = (e, recod) => {
let check = [e.target.value]
let twos = two
let twosid
if (e.target.checked) {
setCheckedList([...checkedList, ...check])
resourceList.rows.forEach(e => {
console.log(e, '==============', check[0]);
if (e.id == check[0]) {
twosid = e.parentId
}
})
twos[twosid] = true
twos[recod.id] = true
setTwo(twos)
} else {
setCheckedList(getDiffer(checkedList, check));
}
}
console.log(two, 'two');
const getDiffer = (arr1, arr2) => {
let arr = arr1.filter(e => {
return !arr2.includes(e)
})
return arr
}
const handleCancel = () => { const handleCancel = () => {
setVisible(false); setVisible(false);
}; };
@ -170,6 +220,45 @@ const EmployeeAuth = (props) => {
const handleCancelUser = () => { const handleCancelUser = () => {
setVisibleUser(false); setVisibleUser(false);
}; };
const roleListBtn = (id) => {
setRoleId(id)
dispatch(actions.humanAffairs.getRoleResource({ id })).then(res => {
if (res.success) {
let two = {}
let checkList = []
if (res.payload.data && res.payload.data.rows.length) {
console.log(res.payload.data, '-------');
checkList = res.payload.data.rows.map(e => {
two[e.resId] = true
return e.resId
})
setCheckedList(checkList)
setTwo(two)
}else{
setCheckedList([])
setTwo(two)
}
}
})
}
const handlOk = () => {
console.log(roleId, '请求的角色id');
console.log(checkedList, '请求三阶参数');
console.log(two, '请求一二阶参数');
let resourceId = [];
for (let item in two) {
if (two[item]) {
resourceId.push(parseInt(item));
}
}
resourceId = [...checkedList, ...resourceId]
if (roleId == undefined || resourceId.length == 0) {
Toast.error('请选择角色和权限!')
} else {
dispatch(actions.humanAffairs.addRoleResource({ roleId, resourceId }))
}
}
return ( return (
<> <>
<div style={{ padding: '0px 12px' }}> <div style={{ padding: '0px 12px' }}>
@ -232,15 +321,15 @@ const EmployeeAuth = (props) => {
<h2>权限范围:</h2> <h2>权限范围:</h2>
<Checkbox style={{ float: 'left', marginTop: 17, }} >全部权限</Checkbox> <Checkbox style={{ float: 'left', marginTop: 17, }} >全部权限</Checkbox>
</div> </div>
{plainOptions.map(e => { {treeList.map(e => {
return <div className='codeList'> return <div className='codeList'>
<Checkbox style={{ borderBottom: '1px solid #f2f2f2', padding: '10px 10px' }} key={e.id}>{e.name}</Checkbox> <Checkbox onChange={(value) => { onChangeOne(value, e) }} style={{ borderBottom: '1px solid #f2f2f2', padding: '10px 10px' }} checked={two[e.id]} key={e.id} value={e.id}>{e.name}</Checkbox>
{e.child.map(i => { {e.child.map(i => {
return <div> return <div>
<Checkbox value={i.id} style={{ borderBottom: '1px solid #f2f2f2', padding: '10px 10px' }} key={i.id} onChange={onCheckAllChange}>{i.name}</Checkbox> <Checkbox value={i.id} style={{ borderBottom: '1px solid #f2f2f2', padding: '10px 10px' }} key={i.id} checked={two[i.id]} onChange={(value) => { onCheckAllChange(value, e) }}>{i.name}</Checkbox>
<CheckboxGroup style={{ width: '100%', borderBottom: '1px solid #f2f2f2', padding: '10px 10px' }} direction='horizontal'> <CheckboxGroup style={{ width: '100%', borderBottom: '1px solid #f2f2f2', padding: '10px 10px' }} direction='horizontal' value={checkedList}>
{ {
i.child.map(s => (<Checkbox key={s.id} value={s.id} >{s.name}</Checkbox>)) i.child.map(s => (<Checkbox onChange={(value) => { checkItem(value, e) }} key={s.id} value={s.id} >{s.name}</Checkbox>))
} }
</CheckboxGroup> </CheckboxGroup>
</div> </div>
@ -248,7 +337,7 @@ const EmployeeAuth = (props) => {
</div> </div>
})} })}
<Button onClick={handlOk} theme='solid' style={{ background: '#0099FF', marginTop: 10 }}>保存</Button>
</Col> </Col>
</Row> </Row>
</div> </div>
@ -266,12 +355,13 @@ const EmployeeAuth = (props) => {
} }
function mapStateToProps(state) { function mapStateToProps(state) {
const { auth, global, roleList, userRoleList } = state; const { auth, global, roleList, userRoleList, resourceList } = state;
return { return {
user: auth.user, user: auth.user,
actions: global.actions, actions: global.actions,
roleList: roleList.data, roleList: roleList.data,
userRoleList: userRoleList.data userRoleList: userRoleList.data,
resourceList: resourceList.data
}; };
} }

3
web/client/src/utils/webapi.js

@ -73,6 +73,9 @@ export const ApiTable = {
delRole:'role/del', delRole:'role/del',
getUserRoleList:'roleUser/list', getUserRoleList:'roleUser/list',
addUserRole:'roleUser/add', addUserRole:'roleUser/add',
getResource:'resource/list',
getRoleResource:'roleResource/list',
addRoleResource:'roleResource/add',
// 请假统计添加备注 // 请假统计添加备注
createVacateRemark: 'attendance/vacate/creat/remark' createVacateRemark: 'attendance/vacate/creat/remark'

Loading…
Cancel
Save