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
113 lines
3.7 KiB
package bahe_service
|
|
|
|
import (
|
|
"errors"
|
|
"hudongzhuanjia/models"
|
|
"hudongzhuanjia/utils/define"
|
|
|
|
"github.com/ouxuanserver/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)
|