互动
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.

102 lines
3.0 KiB

package calorie_service
import (
"errors"
"hudongzhuanjia/models"
"time"
"git.ouxuan.net/tommy/osmanthuswine/src/core"
)
func GetCurrentCalorie(aid, uid, rid int, archId int) (map[string]interface{}, error) {
calorie := new(models.Calorie)
exist, err := calorie.GetCurrent(aid)
if err != nil {
return nil, err
}
if !exist {
return nil, errors.New("轮次尚未开启")
}
calorieUser := new(models.CalorieUser)
exist, err = calorieUser.GetByCalorieIdAndUserId(calorie.Id, archId, uid, rid)
if err != nil {
return nil, err
}
if !exist { // 不存在,代表最后一名
calorieUser.ActivityId = aid
calorieUser.RehearsalId = rid
calorieUser.UserId = uid
calorieUser.ArchId = archId
calorieUser.CalorieId = calorie.Id
calorieUser.Score = 0
calorieUser.IsDelete = false
calorieUser.JoinTime = time.Now().UnixNano()
calorieUser.CreatedAt = time.Now()
calorieUser.UpdatedAt = time.Now()
_, err := models.Add(calorieUser)
if err != nil {
return nil, err
}
rank, err := core.GetXormAuto().Where("is_delete=0 and calorie_id=? and rehearsal_id=?",
calorie.Id, rid).Count(new(models.CalorieUser))
if err != nil {
return nil, err
}
return map[string]interface{}{
"rank": rank,
"score": calorieUser.Score,
"calorie_id": calorie.Id,
}, nil
} else { // 存在
// 计算总数
count, err := core.GetXormAuto().Where("is_delete=0 and calorie_id=? and rehearsal_id=?", calorie.Id, rid).Count(new(models.CalorieUser))
if err != nil {
return nil, err
}
// 计算分数 和 用户偏移量
users := make([]*models.CalorieUser, 0)
err = core.GetXormAuto().Where("is_delete=0 and calorie_id=? and rehearsal_id=? and score<=?",
calorie.Id, rid, calorieUser.Score).Desc("score").Asc("join_time").Find(&users) // desc score asc updated_at
if err != nil {
return nil, err
}
var rank int
for index, u := range users {
if u.Id == calorieUser.Id {
rank = int(count) - len(users) + index + 1 // 总数
break
}
}
return map[string]interface{}{
"rank": rank,
"score": calorieUser.Score,
"calorie_id": calorie.Id,
}, nil
}
}
type CalorieCountResult struct {
Id int `json:"id"`
ActivityId int `json:"activity_id"`
CalorieId int `json:"calorie_id"`
UserId int `json:"user_id"`
Avatar string `json:"avatar"`
Nickname string `json:"nickname"`
Score int `json:"score"`
}
func RankCalorieUser(calorieId, archId, rehearsalId interface{}, limit int) ([]*CalorieCountResult, error) {
// 统计排名
result := make([]*CalorieCountResult, 0)
err := core.GetXormAuto().Table(new(models.CalorieUser)).Alias("c").
Select("c.id, c.activity_id, c.calorie_id, c.user_id, u.avatar, u.nickname, c.score, c.join_time").
Join("LEFT", new(models.User).Alias("u"), "c.user_id=u.id and u.is_delete=0").
Where("c.is_delete=0 and c.calorie_id=? and c.arch_id=? and c.rehearsal_id=?", calorieId, archId, rehearsalId).
Limit(limit).Desc("c.score").Asc("c.join_time").Find(&result)
return result, err
}