123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475 |
- package logic
- import (
- "context"
- "fmt"
- IC "jyBXCore/rpc/init"
- "jyBXCore/rpc/service"
- "jyBXCore/rpc/util"
- "strconv"
- "jyBXCore/rpc/internal/svc"
- "jyBXCore/rpc/type/bxcore"
- "github.com/zeromicro/go-zero/core/logx"
- )
- type ParticipateShowLogic struct {
- ctx context.Context
- svcCtx *svc.ServiceContext
- logx.Logger
- }
- func NewParticipateShowLogic(ctx context.Context, svcCtx *svc.ServiceContext) *ParticipateShowLogic {
- return &ParticipateShowLogic{
- ctx: ctx,
- svcCtx: svcCtx,
- Logger: logx.WithContext(ctx),
- }
- }
- // 列表数据参标信息接口
- func (l *ParticipateShowLogic) ParticipateShow(in *bxcore.ParticipateShowReq) (*bxcore.ParticipateShowRes, error) {
- result := bxcore.ParticipateShowRes{
- ErrMsg: "",
- ErrCode: 0,
- Data: []*bxcore.ShowInfo{},
- }
- // 1. 判断身份是否有权限 不是超级订阅也不是大会员 则直接返回不展示
- baseUserId, _ := strconv.ParseInt(in.NewUserId, 10, 64)
- accountId, _ := strconv.ParseInt(in.AccountId, 10, 64)
- userInfo := IC.Middleground.PowerCheckCenter.Check(in.AppId, in.UserId, baseUserId, accountId, in.EntId, in.PositionType, in.PositionId)
- //不是超级订阅 也不是大会员
- if userInfo.Vip.Status < 0 && userInfo.Member.Status < 0 {
- return &result, fmt.Errorf("没权限")
- }
- participateService := service.NewParticipateBid(in.EntId, in.EntUserId, in.PositionType, in.PositionId)
- // 2. 根据标讯id 查询项目信息 拿到有效的项目id (无项目信息或者已经过开标时间 则不展示按钮 在开标时间内或者没有开标时间字段需要展示)
- // 信息id解密
- infoList, infoSet := service.DecodeId(in.Ids)
- if len(infoList) == 0 {
- return &result, nil
- }
- // 查有效项目id信息
- projectInfos := participateService.GetProjectByInfoId(infoList)
- if projectInfos == nil || len(*projectInfos) == 0 {
- return &result, nil
- }
- // 记录信息id和项目id的映射 用于最后处理返回数据
- infoM, projectIds := service.HandlerProjectId(*projectInfos, infoSet)
- // 3. 查询参标信息 处理按钮 区分个人和企业
- var formatList []*bxcore.ShowInfo
- switch int(in.PositionType) {
- case service.PositionTypePersonal:
- existList := participateService.PersonalExistProject(projectIds)
- formatList = participateService.ListPersonalFormat(existList, infoM)
- case service.PositionTypeEnt:
- partUser := util.NewPartUserInfo(in.EntId, in.EntUserId, in.PositionId, in.PositionType)
- isAllow := partUser.IsALLow()
- existList := participateService.EntExistProject(projectIds) // 查询出已经存在的
- formatList = participateService.ListEntFormat(existList, infoM, isAllow) // 格式化数据
- }
- result.Data = formatList
- return &result, nil
- }
|