org_player.go 3.09 KB
package service

import (
	"errors"
	"github.com/go-admin-team/go-admin-core/sdk/service"
	"gorm.io/gorm"

	"go-admin/app/mobile/service/dto"
	"go-admin/app/operate/models"
	"go-admin/common/actions"
	cDto "go-admin/common/dto"
)

type OrgPlayer struct {
	service.Service
}

// GetPage 获取OrgPlayer列表
func (e *OrgPlayer) GetPage(c *dto.OrgPlayerGetPageReq, p *actions.DataPermission, list *[]dto.OrgPlayerGetPageReply, count *int64) error {
	var err error

	err = e.Orm.Table("org_player as op").
		Select("op.id,op.player_name,op.player_number,op.player_img,op.position,op.sex,op.status").
		Scopes(
			actions.Permission("op", p),
			cDto.PassDel("op"),
			cDto.SetWhere("op", "player_user_id", c.PlayerUserId),
		).
		Find(list).Limit(-1).Offset(-1).
		Count(count).Error
	if err != nil {
		e.Log.Errorf("OrgPlayerService GetPage error:%s \r\n", err)
		return err
	}
	return nil
}

// Get 获取OrgPlayer对象
func (e *OrgPlayer) Get(d *dto.OrgPlayerGetReq, p *actions.DataPermission, model *dto.OrgPlayerGetReply) error {
	var data models.OrgPlayer

	err := e.Orm.Table("org_player as op").
		Select("op.id,op.club_id,oc.club_name,op.team_id,ot.team_name,"+
			"op.player_name,op.player_name_en,op.player_number,"+
			"op.position,op.sex,op.player_img,op.share_conf").
		Joins("left join org_club as oc on op.club_id=oc.id").
		Joins("left join org_team as ot on op.team_id=ot.id").
		Scopes(
			actions.Permission(data.TableName(), p),
		).
		First(model, d.GetId()).Error
	if err != nil && errors.Is(err, gorm.ErrRecordNotFound) {
		err = errors.New("查看对象不存在或无权查看")
		e.Log.Errorf("Service GetOrgPlayer error:%s \r\n", err)
		return err
	}
	if err != nil {
		e.Log.Errorf("db error:%s", err)
		return err
	}
	return nil
}

// Get 获取OrgPlayer对象
func (e *OrgPlayer) GetData(d *dto.OrgPlayerDataGetReq, p *actions.DataPermission, model *dto.OrgPlayerDataGetReply) error {
	var err error
	field := "sum(omtp.scoring) as scoring"

	err = e.Orm.Table("org_match_team_player as omtp").
		Select(field).
		Joins("left join org_match as om on omtp.match_id = om.id and omtp.rounds = om.rounds").
		Scopes(
			actions.Permission("omtp", p),
			cDto.SetWhere("om", "season_id", d.SeasonId),
			cDto.PassDel("omtp"),
			cDto.PassDel("om"),
		).
		Where("omtp.player_id = ?", d.PlayerId).
		First(model).Error
	if err != nil {
		e.Log.Errorf("db error:%s", err)
		return err
	}
	return nil
}

// Get 获取OrgPlayer对象
func (e *OrgPlayer) GetDataMatch(d *dto.OrgPlayerDataGetReq, p *actions.DataPermission, model *dto.OrgPlayerDataGetReply) error {
	var err error

	field := "count(om.id) as count_match"

	err = e.Orm.Table("org_match_team_player as omtp").
		Select(field).
		Joins("left join org_match as om on omtp.match_id = om.id and omtp.rounds = om.rounds").
		Scopes(
			actions.Permission("omtp", p),
			cDto.PassDel("omtp"),
			cDto.SetWhere("om", "season_id", d.SeasonId),
			cDto.PassDel("omtp"),
			cDto.PassDel("om"),
		).
		Where("omtp.player_id = ?", d.PlayerId).
		Group("omtp.match_id and omtp.rounds").
		First(model).Error
	if err != nil {
		e.Log.Errorf("db error:%s", err)
		return err
	}
	return nil
}