123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144 |
- package services
- import (
- "eta_gn/eta_api/global"
- "eta_gn/eta_api/models/system"
- "eta_gn/eta_api/utils"
- )
- func GetRoleTypeCode(roleType string) string {
- var roleTypeCode string
- switch roleType {
- case utils.ROLE_TYPE_ADMIN:
- roleTypeCode = utils.ROLE_TYPE_CODE_ADMIN
- case utils.ROLE_TYPE_FICC_ADMIN:
- roleTypeCode = utils.ROLE_TYPE_CODE_FICC_ADMIN
- case utils.ROLE_TYPE_FICC_SELLER:
- roleTypeCode = utils.ROLE_TYPE_CODE_FICC_SELLER
- case utils.ROLE_TYPE_RAI_ADMIN:
- roleTypeCode = utils.ROLE_TYPE_CODE_RAI_ADMIN
- case utils.ROLE_TYPE_FICC_GROUP, utils.ROLE_TYPE_FICC_MANAGER:
- roleTypeCode = utils.ROLE_TYPE_CODE_FICC_GROUP
- case utils.ROLE_TYPE_RAI_GROUP:
- roleTypeCode = utils.ROLE_TYPE_CODE_RAI_GROUP
- case utils.ROLE_TYPE_FICC_DEPARTMENT:
- roleTypeCode = utils.ROLE_TYPE_CODE_FICC_DEPARTMENT
- case utils.ROLE_TYPE_RAI_DEPARTMENT:
- roleTypeCode = utils.ROLE_TYPE_CODE_RAI_DEPARTMENT
- case utils.ROLE_TYPE_FICC_RESEARCHR:
- roleTypeCode = utils.ROLE_TYPE_CODE_FICC_RESEARCHR
- case utils.ROLE_TYPE_RAI_RESEARCHR:
- roleTypeCode = utils.ROLE_TYPE_CODE_RAI_RESEARCHR
- default:
- roleTypeCode = utils.ROLE_TYPE_ADMIN
- }
- return roleTypeCode
- }
- type GroupNode struct {
- GroupId int
- GroupName string
- Child []*GroupNode
- }
- // GetMenuTreeRecursive 递归菜单树
- func GetMenuTreeRecursive(list []*system.SysMenuItem, parentId int) []*system.SysMenuItem {
- res := make([]*system.SysMenuItem, 0)
- for _, v := range list {
- if v.ParentId == parentId {
- v.Children = GetMenuTreeRecursive(list, v.MenuId)
- res = append(res, v)
- }
- }
- return res
- }
- func BuildGroupTree(list []*system.SysGroupList, current, depth int, node *GroupNode) {
- if current == depth {
- utils.FileLog.Info("到达组织最深层,停止递归")
- return
- }
- for _, v := range list {
- if v.ParentId == node.GroupId {
- subNode := &GroupNode{
- GroupId: v.GroupId,
- GroupName: v.GroupName,
- Child: make([]*GroupNode, 0),
- }
- node.Child = append(node.Child, subNode)
- BuildGroupTree(list, current+1, depth, subNode)
- }
- }
- }
- func DeleteSysGroupByIds(ids []int) (err error) {
- tx := global.DEFAULT_DmSQL.Begin()
- defer func() {
- if err != nil {
- tx.Rollback()
- } else {
- tx.Commit()
- }
- }()
- err = system.DeleteSysGroupByIds(tx, ids)
- if err != nil {
- return
- }
- err = system.ClearSysUserGroupByIds(tx, ids)
- return
- }
- // BuildGroupTreeV2 构建分组树
- func BuildGroupTreeV2(groups []*system.SysFullGroup, groupAdmins map[int][]*system.DepartmentUserTree) map[int][]*system.DepartmentUserTree {
- // 创建分组ID到节点的映射
- groupMap := make(map[int]*system.DepartmentUserTree)
- idList := make([]int, 0, len(groups))
- // 初始化所有节点,不管父子顺序
- for _, g := range groups {
- idList = append(idList, g.GroupId)
- node := &system.DepartmentUserTree{
- NodeId: g.GroupId,
- NodeType: 2,
- NodeName: g.GroupName,
- Children: make([]*system.DepartmentUserTree, 0),
- }
- // 添加该分组的管理员
- if admins, ok := groupAdmins[g.GroupId]; ok {
- node.Children = append(node.Children, admins...)
- }
- groupMap[g.GroupId] = node
- }
- // 构建父子关系
- //rootNodes := make([]*system.DepartmentUserTree, 0)
- // 部门与分组的关系
- groupTree := make(map[int][]*system.DepartmentUserTree)
- for _, g := range groups {
- node := groupMap[g.GroupId]
- if g.ParentId == 0 || g.ParentId == -1 {
- // 如果是根节点
- //rootNodes = append(rootNodes, node)
- nodeList, ok := groupTree[g.DepartmentId]
- if !ok {
- nodeList = make([]*system.DepartmentUserTree, 0)
- }
- groupTree[g.DepartmentId] = append(nodeList, node)
- } else {
- // 如果是非根节点,找到父节点并添加到父节点的Children中
- parentNode, ok := groupMap[g.ParentId]
- if !ok {
- // 父节点不存在,继续处理下一个
- continue
- }
- parentNode.Children = append(parentNode.Children, node)
- }
- }
- return groupTree
- }
|