互动
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

113 lines
3.7 KiB

5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
  1. package bahe_service
  2. import (
  3. "errors"
  4. "hudongzhuanjia/models"
  5. "hudongzhuanjia/utils/define"
  6. "github.com/ouxuanserver/osmanthuswine/src/core"
  7. )
  8. type CountMembersResult struct {
  9. Number int `json:"number,omitempty"`
  10. TeamId int `json:"team_id,omitempty"`
  11. Color string `json:"color,omitempty"`
  12. }
  13. func CountMembers(baheId int) ([]*CountMembersResult, error) {
  14. result := make([]*CountMembersResult, 0)
  15. err := core.GetXormAuto().Table(new(models.BaheTeam)).Alias("t").
  16. Select("count(m.id) as number, t.id as team_id, t.bahe_team_name as color").
  17. Join("left", "ox_bahe_team_member as m", "m.team_id=t.id and m.is_delete=0").
  18. Where("t.is_delete=0 and t.bahe_activity_id = ?", baheId).Desc("color").
  19. GroupBy("t.id").Find(&result)
  20. return result, err
  21. }
  22. func GetMember(bid, rid, uid int) (*models.BaheTeamMember, bool, error) {
  23. member := new(models.BaheTeamMember)
  24. exist, err := core.GetXormAuto().Where("is_delete=0 and rehearsal_id=? and "+
  25. "bahe_activity_id=? and member_id=?", rid, bid, uid).Get(member)
  26. return member, exist, err
  27. }
  28. func GetCurrentTugWar(activityId, uid, rehearsalId interface{}, archId interface{}) (map[string]interface{}, error) {
  29. bahe := new(models.TugOfWar)
  30. exist, err := bahe.GetCurrent(activityId)
  31. if err != nil {
  32. return nil, err
  33. }
  34. if !exist {
  35. return nil, errors.New("轮次尚未开启")
  36. }
  37. member := new(models.BaheTeamMember)
  38. exist, err = member.GetMemberByBaheIdAndUserId(archId, uid, bahe.Id, rehearsalId)
  39. if err != nil {
  40. return nil, err
  41. }
  42. if exist {
  43. return map[string]interface{}{
  44. "member": member,
  45. }, nil
  46. }
  47. if bahe.Model == define.TUGWAR_MODEL_RANDOM {
  48. return map[string]interface{}{
  49. "model": bahe.Model,
  50. "bahe_activity_id": bahe.Id,
  51. }, nil
  52. }
  53. res, err := CountMembers(bahe.Id)
  54. if err != nil {
  55. return nil, err
  56. }
  57. return map[string]interface{}{
  58. "list": res,
  59. "model": bahe.Model,
  60. "bahe_activity_id": bahe.Id,
  61. "limit": bahe.Number,
  62. }, nil
  63. }
  64. type JoinTeamResult struct {
  65. Number int
  66. TeamId int
  67. TeamName string
  68. }
  69. func GetJoinTeamByTeamId(teamId, rehearsalId, archId interface{}) (*JoinTeamResult, bool, error) {
  70. result := new(JoinTeamResult)
  71. exist, err := core.GetXormAuto().Table(new(models.BaheTeam)).Alias("t").
  72. Select("t.id as team_id, t.bahe_team_name as team_name, count(m.id) as number").
  73. Join("LEFT", new(models.BaheTeamMember).Alias("m"),
  74. "m.team_id=t.id and m.rehearsal_id=? and m.arch_id=?", rehearsalId, archId).
  75. Where("t.is_delete=0 and t.id=?", teamId).
  76. GroupBy("t.id").Get(result)
  77. return result, exist, err
  78. }
  79. func GetJoinTeamByBaheId(baheId, rehearsalId, archId interface{}) (*JoinTeamResult, bool, error) {
  80. result := new(JoinTeamResult)
  81. exist, err := core.GetXormAuto().Table(new(models.BaheTeam)).Alias("t").
  82. Select("t.id as team_id, t.bahe_team_name as team_name, count(m.id) as number").
  83. Join("LEFT", new(models.BaheTeamMember).Alias("m"),
  84. "m.team_id=t.id and m.rehearsal_id=? and m.arch_id=?", rehearsalId, archId).
  85. Where("t.is_delete=0 and t.bahe_activity_id=? ", baheId).
  86. GroupBy("t.id").Asc("number").Get(result)
  87. return result, exist, err
  88. }
  89. //
  90. //team := new(JoinTeamResult)
  91. //session := core.GetXormAuto().Table(new(models.BaheTeam)).Alias("t").
  92. // Select("t.id as team_id, t.bahe_team_name as team_name, count(m.id) as number").
  93. // Join("LEFT", new(models.BaheTeamMember).Alias("m"),
  94. // "m.team_id=t.id and m.is_delete=0 and m.rehearsal_id=?", activity.RehearsalId)
  95. //if teamId == 0 { // 人数最少的一队
  96. // session = session.Where("t.is_delete=0 and t.bahe_activity_id=? ", bahe.Id).
  97. // GroupBy("t.id").Asc("number")
  98. //} else {
  99. // session = session.Where("t.is_delete=0 and t.id=?", teamId).GroupBy("t.id")
  100. //}
  101. //exist, err = session.Get(team)