package bahe_service import ( "errors" "hudongzhuanjia/models" "hudongzhuanjia/utils/define" "git.ouxuan.net/tommy/osmanthuswine/src/core" ) type CountMembersResult struct { Number int `json:"number,omitempty"` TeamId int `json:"team_id,omitempty"` Color string `json:"color,omitempty"` } func CountMembers(baheId int) ([]*CountMembersResult, error) { result := make([]*CountMembersResult, 0) err := core.GetXormAuto().Table(new(models.BaheTeam)).Alias("t"). Select("count(m.id) as number, t.id as team_id, t.bahe_team_name as color"). Join("left", "ox_bahe_team_member as m", "m.team_id=t.id and m.is_delete=0"). Where("t.is_delete=0 and t.bahe_activity_id = ?", baheId).Desc("color"). GroupBy("t.id").Find(&result) return result, err } func GetMember(bid, rid, uid int) (*models.BaheTeamMember, bool, error) { member := new(models.BaheTeamMember) exist, err := core.GetXormAuto().Where("is_delete=0 and rehearsal_id=? and "+ "bahe_activity_id=? and member_id=?", rid, bid, uid).Get(member) return member, exist, err } func GetCurrentTugWar(activityId, uid, rehearsalId interface{}, archId interface{}) (map[string]interface{}, error) { bahe := new(models.TugOfWar) exist, err := bahe.GetCurrent(activityId) if err != nil { return nil, err } if !exist { return nil, errors.New("轮次尚未开启") } member := new(models.BaheTeamMember) exist, err = member.GetMemberByBaheIdAndUserId(archId, uid, bahe.Id, rehearsalId) if err != nil { return nil, err } if exist { return map[string]interface{}{ "member": member, }, nil } if bahe.Model == define.TUGWAR_MODEL_RANDOM { return map[string]interface{}{ "model": bahe.Model, "bahe_activity_id": bahe.Id, }, nil } res, err := CountMembers(bahe.Id) if err != nil { return nil, err } return map[string]interface{}{ "list": res, "model": bahe.Model, "bahe_activity_id": bahe.Id, "limit": bahe.Number, }, nil } type JoinTeamResult struct { Number int TeamId int TeamName string } func GetJoinTeamByTeamId(teamId, rehearsalId, archId interface{}) (*JoinTeamResult, bool, error) { result := new(JoinTeamResult) exist, err := core.GetXormAuto().Table(new(models.BaheTeam)).Alias("t"). Select("t.id as team_id, t.bahe_team_name as team_name, count(m.id) as number"). Join("LEFT", new(models.BaheTeamMember).Alias("m"), "m.team_id=t.id and m.rehearsal_id=? and m.arch_id=?", rehearsalId, archId). Where("t.is_delete=0 and t.id=?", teamId). GroupBy("t.id").Get(result) return result, exist, err } func GetJoinTeamByBaheId(baheId, rehearsalId, archId interface{}) (*JoinTeamResult, bool, error) { result := new(JoinTeamResult) exist, err := core.GetXormAuto().Table(new(models.BaheTeam)).Alias("t"). Select("t.id as team_id, t.bahe_team_name as team_name, count(m.id) as number"). Join("LEFT", new(models.BaheTeamMember).Alias("m"), "m.team_id=t.id and m.rehearsal_id=? and m.arch_id=?", rehearsalId, archId). Where("t.is_delete=0 and t.bahe_activity_id=? ", baheId). GroupBy("t.id").Asc("number").Get(result) return result, exist, err } // //team := new(JoinTeamResult) //session := core.GetXormAuto().Table(new(models.BaheTeam)).Alias("t"). // Select("t.id as team_id, t.bahe_team_name as team_name, count(m.id) as number"). // Join("LEFT", new(models.BaheTeamMember).Alias("m"), // "m.team_id=t.id and m.is_delete=0 and m.rehearsal_id=?", activity.RehearsalId) //if teamId == 0 { // 人数最少的一队 // session = session.Where("t.is_delete=0 and t.bahe_activity_id=? ", bahe.Id). // GroupBy("t.id").Asc("number") //} else { // session = session.Where("t.is_delete=0 and t.id=?", teamId).GroupBy("t.id") //} //exist, err = session.Get(team)