system.go 2.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  1. package services
  2. import (
  3. "eta/eta_mobile/models/company"
  4. "eta/eta_mobile/models/system"
  5. "fmt"
  6. )
  7. // CheckAdminIsSameBigGroup 判断是否两个系统用户是否同一个大组内
  8. func CheckAdminIsSameBigGroup(adminInfo1, adminInfo2 *system.Admin) (isSame bool, err error) {
  9. // 如果销售和创建人是同一个小组
  10. if adminInfo1.GroupId == adminInfo2.GroupId {
  11. isSame = true
  12. return
  13. }
  14. var admin1BigGroupId, admin2BigGroupId int
  15. //获取第一个系统用户的大组id
  16. {
  17. //获取该账号的大组id
  18. pid, tmpErr := company.GetParentIdFromGroup(adminInfo1.GroupId)
  19. if tmpErr != nil {
  20. err = tmpErr
  21. return
  22. }
  23. if pid != nil && *pid > 0 {
  24. //该账号放在了三级分组下
  25. admin1BigGroupId = *pid
  26. } else {
  27. //该账号放在了二级分组下
  28. admin1BigGroupId = adminInfo1.GroupId
  29. }
  30. }
  31. //获取第二个系统用户的大组id
  32. {
  33. //获取该账号的大组id
  34. pid, tmpErr := company.GetParentIdFromGroup(adminInfo2.GroupId)
  35. if tmpErr != nil {
  36. err = tmpErr
  37. return
  38. }
  39. if pid != nil && *pid > 0 {
  40. //该账号放在了三级分组下
  41. admin2BigGroupId = *pid
  42. } else {
  43. //该账号放在了二级分组下
  44. admin2BigGroupId = adminInfo2.GroupId
  45. }
  46. }
  47. if admin1BigGroupId == admin2BigGroupId {
  48. isSame = true
  49. return
  50. }
  51. return
  52. }
  53. func BuildGroupTree(rootNode *system.GroupNode, groupList []*system.SysFullGroup, depth, current int) {
  54. if current >= depth {
  55. return
  56. }
  57. for _, group := range groupList {
  58. if group.ParentId == rootNode.GroupId {
  59. childNode := &system.GroupNode{
  60. GroupId: group.GroupId,
  61. GroupName: group.GroupName,
  62. }
  63. BuildGroupTree(childNode, groupList, depth, current+1)
  64. rootNode.Child = append(rootNode.Child, childNode)
  65. }
  66. }
  67. }
  68. func GetGroupName(nodes []*system.GroupNode, groupId int) (find bool, groupName string) {
  69. for _, child := range nodes {
  70. if child.GroupId == groupId {
  71. return true, child.GroupName
  72. }
  73. if len(child.Child) > 0 {
  74. find, subGroupName := GetGroupName(child.Child, groupId)
  75. if find {
  76. groupName = fmt.Sprintf("%s/%s", child.GroupName, subGroupName)
  77. return true, groupName
  78. }
  79. }
  80. }
  81. return false, ""
  82. }