finish cdkey
This commit is contained in:
parent
9675612496
commit
aea644c553
@ -1,8 +1,10 @@
|
|||||||
package game
|
package game
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"admin/apps/game/config"
|
||||||
"admin/apps/game/server"
|
"admin/apps/game/server"
|
||||||
"admin/apps/game/service"
|
"admin/apps/game/service"
|
||||||
|
"admin/internal/context"
|
||||||
"admin/internal/global"
|
"admin/internal/global"
|
||||||
"admin/lib/node"
|
"admin/lib/node"
|
||||||
)
|
)
|
||||||
@ -12,13 +14,15 @@ func initFun(app *node.Application) error {
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
panic(err)
|
panic(err)
|
||||||
}
|
}
|
||||||
srv := server.New(svc) // 初始化http服务
|
sdkEngine := app.WithServer("内部游戏调用的sdk服务", ":"+config.BootFlags.ApiSDKPort, context.NewWebContext)
|
||||||
srv.Route(global.GLOB_API_ENGINE) // 初始化http服务路由
|
srv := server.New(svc) // 初始化http服务
|
||||||
|
srv.Route(global.GLOB_API_ENGINE, sdkEngine) // 初始化http服务路由
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func New() *node.ApplicationDescInfo {
|
func New() *node.ApplicationDescInfo {
|
||||||
app := node.NewApplicationDescInfo("game", initFun)
|
app := node.NewApplicationDescInfo("game", initFun).
|
||||||
|
WithOptions(node.WithAppBootFlag(config.BootFlags))
|
||||||
return app
|
return app
|
||||||
}
|
}
|
||||||
|
|
||||||
|
7
admin/apps/game/config/flags.go
Normal file
7
admin/apps/game/config/flags.go
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
package config
|
||||||
|
|
||||||
|
var BootFlags = &GameBootFlags{}
|
||||||
|
|
||||||
|
type GameBootFlags struct {
|
||||||
|
ApiSDKPort string `env:"api_sdk_port" default:"8180" desc:"sdk接口,内部游戏调用地址"`
|
||||||
|
}
|
@ -3,7 +3,11 @@ package domain
|
|||||||
import (
|
import (
|
||||||
"admin/apps/game/domain/entity"
|
"admin/apps/game/domain/entity"
|
||||||
"admin/apps/game/domain/repo"
|
"admin/apps/game/domain/repo"
|
||||||
|
"admin/apps/game/model/dto"
|
||||||
|
"admin/internal/errcode"
|
||||||
|
"admin/lib/cdkey"
|
||||||
"gorm.io/gorm"
|
"gorm.io/gorm"
|
||||||
|
"time"
|
||||||
)
|
)
|
||||||
|
|
||||||
type CDKeyService struct {
|
type CDKeyService struct {
|
||||||
@ -14,14 +18,60 @@ func NewCDKeyService(db *gorm.DB) *CDKeyService {
|
|||||||
return &CDKeyService{repo: repo.NewCDKeyRepo(db)}
|
return &CDKeyService{repo: repo.NewCDKeyRepo(db)}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (svc *CDKeyService) AddCount(id int, delta int) (int, error) {
|
func (svc *CDKeyService) AddCount(projectId, id int, delta int) (int, error) {
|
||||||
et, err := svc.repo.AddCount(id, delta)
|
et, err := svc.repo.AddCount(projectId, id, delta)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return 0, err
|
return 0, err
|
||||||
}
|
}
|
||||||
return et.GetCount(), nil
|
return et.GetCount(), nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (svc *CDKeyService) Get(id int) (*entity.CDKey, bool, error) {
|
func (svc *CDKeyService) Get(projectId, id int) (*entity.CDKey, bool, error) {
|
||||||
return svc.repo.GetByID(id)
|
return svc.repo.GetByID(projectId, id)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (svc *CDKeyService) CDKeyUse(params *dto.CDKeyUseReq) (*entity.CDKey, error) {
|
||||||
|
var cdkeyEt *entity.CDKey
|
||||||
|
var find bool
|
||||||
|
var err error
|
||||||
|
cdkeyInfo, ok := cdkey.DecodeCDKey(params.Key)
|
||||||
|
if !ok {
|
||||||
|
// 可能是通用码,通过数据库查询通用码
|
||||||
|
cdkeyEt, find, err = svc.repo.GetByKey(params.ProjectId, params.Key)
|
||||||
|
} else {
|
||||||
|
cdkeyEt, find, err = svc.repo.GetByID(params.ProjectId, cdkeyInfo.Batch)
|
||||||
|
}
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
if !find {
|
||||||
|
return nil, errcode.New(errcode.ParamsInvalid, "not found project:%v cdkey info by key:%v", params.ProjectId, params.Key)
|
||||||
|
}
|
||||||
|
|
||||||
|
// 校验区服、时间
|
||||||
|
if err = cdkeyEt.CheckCanUse(params.ServerID); err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
// 校验是否使用过
|
||||||
|
usedInfo, find, err := svc.repo.GetUsedHistory(cdkeyEt, params.Key, params.ServerID, params.RoleID)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
if find {
|
||||||
|
// 只要使用过同一批的就没法再用
|
||||||
|
return nil, errcode.New(errcode.CDKeyAlreadyUsed, "already used %v in %v", usedInfo.Key, usedInfo.CreatedAt.Format(time.DateTime))
|
||||||
|
}
|
||||||
|
|
||||||
|
err = svc.repo.RecordUse(cdkeyEt, params)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
return cdkeyEt, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (svc *CDKeyService) GetUsedHistoryList(projectId int, cdKeyID int) ([]*dto.CDKeyUsedInfo, error) {
|
||||||
|
list, err := svc.repo.GetUsedHistoryList(projectId, cdKeyID)
|
||||||
|
return list, err
|
||||||
}
|
}
|
||||||
|
@ -2,8 +2,11 @@ package entity
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"admin/apps/game/model"
|
"admin/apps/game/model"
|
||||||
|
"admin/apps/game/model/dto"
|
||||||
"admin/internal/consts"
|
"admin/internal/consts"
|
||||||
|
"admin/internal/errcode"
|
||||||
"admin/lib/cdkey"
|
"admin/lib/cdkey"
|
||||||
|
"time"
|
||||||
)
|
)
|
||||||
|
|
||||||
var MaxKeyNum = 100000 // 每个批次直接搞10w个,不然运营想补加码,算法又要一开始定好数量
|
var MaxKeyNum = 100000 // 每个批次直接搞10w个,不然运营想补加码,算法又要一开始定好数量
|
||||||
@ -40,3 +43,49 @@ func (c *CDKey) AddCount(delta int) {
|
|||||||
func (c *CDKey) GetCount() int {
|
func (c *CDKey) GetCount() int {
|
||||||
return c.Po.CodeNum
|
return c.Po.CodeNum
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (c *CDKey) CheckCanUse(roleServerId string) error {
|
||||||
|
if ok := c.checkServerId(roleServerId); !ok {
|
||||||
|
return errcode.New(errcode.CDKeyInvalid, "server_id %v not in %v", roleServerId, c.Po.ServerIDs)
|
||||||
|
}
|
||||||
|
timeNow := time.Now()
|
||||||
|
if c.Po.ValidStartTime.Valid {
|
||||||
|
if c.Po.ValidStartTime.Time.After(timeNow) {
|
||||||
|
return errcode.New(errcode.CDKeyAlreadyExpired, "not reach start time:%v", c.Po.ValidStartTime.Time.Format(time.DateTime))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if c.Po.ValidEndTime.Valid {
|
||||||
|
if c.Po.ValidEndTime.Time.Before(timeNow) {
|
||||||
|
return errcode.New(errcode.CDKeyAlreadyExpired, "expired at:%v", c.Po.ValidEndTime.Time.Format(time.DateTime))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c *CDKey) checkServerId(serverId string) bool {
|
||||||
|
if len(c.Po.ServerIDs) == 0 {
|
||||||
|
return true
|
||||||
|
}
|
||||||
|
if len(c.Po.ServerIDs) == 1 && c.Po.ServerIDs[0] == "" {
|
||||||
|
return true
|
||||||
|
}
|
||||||
|
for _, id := range c.Po.ServerIDs {
|
||||||
|
if id == serverId {
|
||||||
|
return true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c *CDKey) RewardItemsView() []*dto.ItemInfo {
|
||||||
|
items := make([]*dto.ItemInfo, 0, len(c.Po.Attach))
|
||||||
|
for _, v := range c.Po.Attach {
|
||||||
|
items = append(items, &dto.ItemInfo{
|
||||||
|
ItemID: int(v.ID),
|
||||||
|
ItemNum: v.Num,
|
||||||
|
ItemType: v.ItemType,
|
||||||
|
Desc: v.Desc,
|
||||||
|
})
|
||||||
|
}
|
||||||
|
return items
|
||||||
|
}
|
||||||
|
@ -169,6 +169,16 @@ func parseStr2FieldValue(field reflect.StructField, rawValue any) (realSetValue
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
i := 0
|
||||||
|
for {
|
||||||
|
if i >= len(list) {
|
||||||
|
break
|
||||||
|
}
|
||||||
|
if list[i] == "" {
|
||||||
|
list = append(list[:i], list[i+1:]...)
|
||||||
|
}
|
||||||
|
i++
|
||||||
|
}
|
||||||
parsedValue = list
|
parsedValue = list
|
||||||
} else if typeName == "[]*model.MailAttachItem" {
|
} else if typeName == "[]*model.MailAttachItem" {
|
||||||
items := make([]*model.MailAttachItem, 0)
|
items := make([]*model.MailAttachItem, 0)
|
||||||
|
110
admin/apps/game/domain/projects/smdl/notice.go
Normal file
110
admin/apps/game/domain/projects/smdl/notice.go
Normal file
@ -0,0 +1,110 @@
|
|||||||
|
package smdl
|
||||||
|
|
||||||
|
import (
|
||||||
|
"admin/apps/game/domain/entity"
|
||||||
|
"admin/apps/game/model"
|
||||||
|
"admin/apps/game/model/dto"
|
||||||
|
"admin/internal/consts"
|
||||||
|
"admin/internal/errcode"
|
||||||
|
"admin/lib/httpclient"
|
||||||
|
"admin/lib/xlog"
|
||||||
|
"net/url"
|
||||||
|
"strconv"
|
||||||
|
"time"
|
||||||
|
)
|
||||||
|
|
||||||
|
type NoticeHook struct {
|
||||||
|
}
|
||||||
|
|
||||||
|
func (hook *NoticeHook) Create(projectInfo *entity.Project, resource string, dtoObj dto.CommonDtoValues) error {
|
||||||
|
alisrvAddr := projectInfo.GetApiAddr()
|
||||||
|
if alisrvAddr == "" {
|
||||||
|
return errcode.New(errcode.ServerError, "项目%v没有配置api服务器地址", projectInfo.Po.Name)
|
||||||
|
}
|
||||||
|
|
||||||
|
et := (&entity.CommonResource{}).FromPo(&model.Ban{}).FromDto(dtoObj)
|
||||||
|
banInfo := et.ToPo().(*model.Ban)
|
||||||
|
|
||||||
|
banApi := ""
|
||||||
|
switch banInfo.BanType {
|
||||||
|
case consts.BanType_Role:
|
||||||
|
banApi = "banrole"
|
||||||
|
case consts.BanType_RoleChat:
|
||||||
|
banApi = "banroletalk"
|
||||||
|
default:
|
||||||
|
xlog.Warnf("神魔大陆不支持此类型的封禁:%v", banInfo.BanType)
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
roleId := banInfo.Value
|
||||||
|
|
||||||
|
params := &url.Values{}
|
||||||
|
params.Add("server", banInfo.ServerConfID)
|
||||||
|
params.Add("roleid", roleId)
|
||||||
|
|
||||||
|
expireAt := banInfo.ExpireAt.Unix()
|
||||||
|
|
||||||
|
if expireAt <= 0 {
|
||||||
|
// 解封
|
||||||
|
params.Add("forbidtime", "0")
|
||||||
|
params.Add("desc", banInfo.BanReason)
|
||||||
|
params.Add("notifytouser", banInfo.BanNotifyReason)
|
||||||
|
} else {
|
||||||
|
dura := (expireAt - time.Now().Unix()) / 60 // 神魔大陆封禁是分钟
|
||||||
|
if dura <= 0 {
|
||||||
|
// 解封
|
||||||
|
params.Add("forbidtime", "0")
|
||||||
|
} else {
|
||||||
|
params.Add("forbidtime", strconv.FormatInt(dura, 10))
|
||||||
|
params.Add("desc", banInfo.BanReason)
|
||||||
|
params.Add("notifytouser", banInfo.BanNotifyReason)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
rsp := make(map[string]any)
|
||||||
|
err := httpclient.Request(alisrvAddr+"/"+banApi, "get", params, &rsp)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (hook *NoticeHook) Delete(projectInfo *entity.Project, resource string, dtoObj dto.CommonDtoValues) error {
|
||||||
|
alisrvAddr := projectInfo.GetApiAddr()
|
||||||
|
if alisrvAddr == "" {
|
||||||
|
return errcode.New(errcode.ServerError, "项目%v没有配置api服务器地址", projectInfo.Po.Name)
|
||||||
|
}
|
||||||
|
|
||||||
|
et := (&entity.CommonResource{}).FromPo(&model.Ban{}).FromDto(dtoObj)
|
||||||
|
banInfo := et.ToPo().(*model.Ban)
|
||||||
|
|
||||||
|
banApi := ""
|
||||||
|
switch banInfo.BanType {
|
||||||
|
case consts.BanType_Role:
|
||||||
|
banApi = "banrole"
|
||||||
|
case consts.BanType_RoleChat:
|
||||||
|
banApi = "banroletalkdel"
|
||||||
|
default:
|
||||||
|
xlog.Warnf("神魔大陆不支持此类型的封禁:%v", banInfo.BanType)
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
roleId := banInfo.Value
|
||||||
|
params := &url.Values{}
|
||||||
|
params.Add("server", banInfo.ServerConfID)
|
||||||
|
params.Add("roleid", roleId)
|
||||||
|
|
||||||
|
// 解封
|
||||||
|
params.Add("forbidtime", "-1")
|
||||||
|
params.Add("desc", "")
|
||||||
|
params.Add("notifytouser", "")
|
||||||
|
|
||||||
|
rsp := make(map[string]any)
|
||||||
|
err := httpclient.Request(alisrvAddr+"/"+banApi, "get", params, &rsp)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}
|
@ -3,14 +3,20 @@ package repo
|
|||||||
import (
|
import (
|
||||||
"admin/apps/game/domain/entity"
|
"admin/apps/game/domain/entity"
|
||||||
"admin/apps/game/model"
|
"admin/apps/game/model"
|
||||||
|
"admin/apps/game/model/dto"
|
||||||
"admin/internal/errcode"
|
"admin/internal/errcode"
|
||||||
"errors"
|
"errors"
|
||||||
"gorm.io/gorm"
|
"gorm.io/gorm"
|
||||||
|
"time"
|
||||||
)
|
)
|
||||||
|
|
||||||
type ICDKeyRepo interface {
|
type ICDKeyRepo interface {
|
||||||
GetByID(id int) (*entity.CDKey, bool, error)
|
GetByID(projectId, id int) (*entity.CDKey, bool, error)
|
||||||
AddCount(id int, delta int) (*entity.CDKey, error)
|
GetByKey(projectId int, key string) (*entity.CDKey, bool, error)
|
||||||
|
AddCount(projectId, id int, delta int) (*entity.CDKey, error)
|
||||||
|
GetUsedHistory(batchInfo *entity.CDKey, key string, serverId, roleId string) (*model.CDKeyUsed, bool, error)
|
||||||
|
RecordUse(batchInfo *entity.CDKey, params *dto.CDKeyUseReq) error
|
||||||
|
GetUsedHistoryList(projectId, id int) ([]*dto.CDKeyUsedInfo, error)
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewCDKeyRepo(db *gorm.DB) ICDKeyRepo {
|
func NewCDKeyRepo(db *gorm.DB) ICDKeyRepo {
|
||||||
@ -21,24 +27,24 @@ type cdKeyRepoImpl struct {
|
|||||||
db *gorm.DB
|
db *gorm.DB
|
||||||
}
|
}
|
||||||
|
|
||||||
func (impl *cdKeyRepoImpl) AddCount(id int, delta int) (*entity.CDKey, error) {
|
func (impl *cdKeyRepoImpl) AddCount(projectId, id int, delta int) (*entity.CDKey, error) {
|
||||||
po := new(model.CDKey)
|
po := new(model.CDKey)
|
||||||
err := impl.db.Where("id = ?", id).First(po).Error
|
err := impl.db.Where("project_id = ? and id = ?", projectId, id).First(po).Error
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, errcode.New(errcode.ParamsInvalid, "not found cdkey conf:%v", id)
|
return nil, errcode.New(errcode.ParamsInvalid, "not found cdkey conf:%v", id)
|
||||||
}
|
}
|
||||||
et := entity.NewCDKey(po)
|
et := entity.NewCDKey(po)
|
||||||
et.AddCount(delta)
|
et.AddCount(delta)
|
||||||
err = impl.db.Where("id = ?", id).Updates(po).Error
|
err = impl.db.Where("project_id = ? and id = ?", projectId, id).Updates(po).Error
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, errcode.New(errcode.DBError, "update data:%+v error:%v", po, id)
|
return nil, errcode.New(errcode.DBError, "update data:%+v error:%v", po, id)
|
||||||
}
|
}
|
||||||
return et, nil
|
return et, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (impl *cdKeyRepoImpl) GetByID(id int) (*entity.CDKey, bool, error) {
|
func (impl *cdKeyRepoImpl) GetByID(projectId, id int) (*entity.CDKey, bool, error) {
|
||||||
po := new(model.CDKey)
|
po := new(model.CDKey)
|
||||||
err := impl.db.Where("id = ?", id).First(po).Error
|
err := impl.db.Where("project_id = ? and id = ?", projectId, id).First(po).Error
|
||||||
if err != nil {
|
if err != nil {
|
||||||
if errors.Is(err, gorm.ErrRecordNotFound) {
|
if errors.Is(err, gorm.ErrRecordNotFound) {
|
||||||
return nil, false, nil
|
return nil, false, nil
|
||||||
@ -47,3 +53,71 @@ func (impl *cdKeyRepoImpl) GetByID(id int) (*entity.CDKey, bool, error) {
|
|||||||
}
|
}
|
||||||
return entity.NewCDKey(po), true, nil
|
return entity.NewCDKey(po), true, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (impl *cdKeyRepoImpl) GetByKey(projectId int, key string) (*entity.CDKey, bool, error) {
|
||||||
|
po := new(model.CDKey)
|
||||||
|
err := impl.db.Where("project_id = ? and code = ?", projectId, key).First(po).Error
|
||||||
|
if err != nil {
|
||||||
|
if errors.Is(err, gorm.ErrRecordNotFound) {
|
||||||
|
return nil, false, nil
|
||||||
|
}
|
||||||
|
return nil, false, errcode.New(errcode.ParamsInvalid, "not found cdkey conf:%v", key)
|
||||||
|
}
|
||||||
|
return entity.NewCDKey(po), true, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (impl *cdKeyRepoImpl) GetUsedHistory(batchInfo *entity.CDKey, key string, serverId, roleId string) (*model.CDKeyUsed, bool, error) {
|
||||||
|
po := new(model.CDKeyUsed)
|
||||||
|
// 获取同一批次角色的使用情况,同一批只能使用一次
|
||||||
|
err := impl.db.Where("project_id = ? and cd_key_id = ? and server_id = ? and role_id = ?",
|
||||||
|
batchInfo.Po.ProjectId, batchInfo.Po.ID, serverId, roleId).First(po).Error
|
||||||
|
if err != nil {
|
||||||
|
if errors.Is(err, gorm.ErrRecordNotFound) {
|
||||||
|
return nil, false, nil
|
||||||
|
}
|
||||||
|
return nil, false, errcode.New(errcode.ParamsInvalid, "found cdkey use:%v,%v,%v,%v error:%v",
|
||||||
|
batchInfo.Po.ProjectId, serverId, roleId, key, err)
|
||||||
|
}
|
||||||
|
return po, true, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (impl *cdKeyRepoImpl) RecordUse(batchInfo *entity.CDKey, params *dto.CDKeyUseReq) error {
|
||||||
|
po := &model.CDKeyUsed{
|
||||||
|
ProjectId: batchInfo.Po.ProjectId,
|
||||||
|
CDKeyId: batchInfo.Po.ID,
|
||||||
|
ServerID: params.ServerID,
|
||||||
|
Account: params.Account,
|
||||||
|
RoleID: params.RoleID,
|
||||||
|
RoleName: params.RoleName,
|
||||||
|
Key: params.Key,
|
||||||
|
IP: params.IP,
|
||||||
|
DeviceId: params.DeviceID,
|
||||||
|
}
|
||||||
|
err := impl.db.Save(po).Error
|
||||||
|
if err != nil {
|
||||||
|
return errcode.New(errcode.CDKeyInvalid, "save db(%+v) error:%v", po, err)
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (impl *cdKeyRepoImpl) GetUsedHistoryList(projectId, id int) ([]*dto.CDKeyUsedInfo, error) {
|
||||||
|
list := make([]*model.CDKeyUsed, 0)
|
||||||
|
err := impl.db.Where("project_id = ? and cd_key_id = ?", projectId, id).Find(&list).Error
|
||||||
|
if err != nil {
|
||||||
|
return nil, errcode.New(errcode.DBError, "GetUsedHistoryList %v %v error:%v", projectId, id, err)
|
||||||
|
}
|
||||||
|
retList := make([]*dto.CDKeyUsedInfo, 0, len(list))
|
||||||
|
for _, v := range list {
|
||||||
|
retList = append(retList, &dto.CDKeyUsedInfo{
|
||||||
|
ServerID: v.ServerID,
|
||||||
|
Account: v.Account,
|
||||||
|
RoleID: v.RoleID,
|
||||||
|
RoleName: v.RoleName,
|
||||||
|
Key: v.Key,
|
||||||
|
IP: v.IP,
|
||||||
|
DeviceID: v.DeviceId,
|
||||||
|
CreatedAt: v.CreatedAt.Format(time.DateTime),
|
||||||
|
})
|
||||||
|
}
|
||||||
|
return retList, nil
|
||||||
|
}
|
||||||
|
@ -15,10 +15,10 @@ func init() {
|
|||||||
type CDKey struct {
|
type CDKey struct {
|
||||||
ID int `gorm:"primarykey" readonly:"true"`
|
ID int `gorm:"primarykey" readonly:"true"`
|
||||||
ProjectId int `gorm:"index:idx_project_id"`
|
ProjectId int `gorm:"index:idx_project_id"`
|
||||||
Name string `name:"礼包说明" required:"true" uneditable:"true"`
|
Name string `gorm:"type:varchar(100);unique" name:"礼包说明" required:"true" uneditable:"true"`
|
||||||
ServerIDs []string `gorm:"type:json;serializer:json" name:"区服" desc:"不选就是全服通用" type:"[]string" choices:"GetChoiceServers" multi_choice:"true" uneditable:"true""`
|
ServerIDs []string `gorm:"type:json;serializer:json" name:"区服" desc:"不选就是全服通用" type:"[]string" choices:"GetChoiceServers" multi_choice:"true" uneditable:"true""`
|
||||||
CodeType int `name:"礼包类型" required:"true" choices:"GetCodeTypeChoices" uneditable:"true"`
|
CodeType int `name:"礼包类型" required:"true" choices:"GetCodeTypeChoices" uneditable:"true"`
|
||||||
Code string `name:"礼包码" desc:"一码通用才配置"`
|
Code string `gorm:"type:VARCHAR(50);index" name:"礼包码" desc:"一码通用才配置"`
|
||||||
CodeNum int `name:"礼包数量" desc:"一码一用才配置"`
|
CodeNum int `name:"礼包数量" desc:"一码一用才配置"`
|
||||||
ValidStartTime sql.NullTime `name:"生效起始时间"`
|
ValidStartTime sql.NullTime `name:"生效起始时间"`
|
||||||
ValidEndTime sql.NullTime `name:"生效结束时间"`
|
ValidEndTime sql.NullTime `name:"生效结束时间"`
|
||||||
|
@ -11,12 +11,15 @@ func init() {
|
|||||||
|
|
||||||
type CDKeyUsed struct {
|
type CDKeyUsed struct {
|
||||||
ID int `gorm:"primarykey" readonly:"true"`
|
ID int `gorm:"primarykey" readonly:"true"`
|
||||||
ProjectId int `gorm:"index:idx_project_id"`
|
ProjectId int `gorm:"index:idx_project_id;uniqueIndex:one_time_used"`
|
||||||
ServerID string `name:"所属区服" choices:"GetChoiceServers" required:"true" where:"eq"`
|
CDKeyId int `gorm:"index:idx_cdkeyid;uniqueIndex:one_time_used"`
|
||||||
Account string `gorm:"type:varchar(255);index:idx_account"`
|
ServerID string `gorm:"type:varchar(30);uniqueIndex:one_time_used" name:"所属区服" choices:"GetChoiceServers" required:"true" where:"eq"`
|
||||||
RoleID string `gorm:"type:varchar(255);index:idx_role_id"`
|
Account string `gorm:"type:varchar(128);index:idx_account"`
|
||||||
|
RoleID string `gorm:"type:varchar(128);index:idx_role_id;uniqueIndex:one_time_used"`
|
||||||
RoleName string `gorm:"type:varchar(255)"`
|
RoleName string `gorm:"type:varchar(255)"`
|
||||||
Key string `gorm:"type:varchar(255);index:idx_key"`
|
Key string `gorm:"type:varchar(50);index:idx_key;"`
|
||||||
|
IP string `gorm:"type:varchar(20)"`
|
||||||
|
DeviceId string `gorm:"type:varchar(50)"`
|
||||||
CreatedAt time.Time `readonly:"true"`
|
CreatedAt time.Time `readonly:"true"`
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,9 +1,10 @@
|
|||||||
package dto
|
package dto
|
||||||
|
|
||||||
type WebRspData struct {
|
type WebRspData struct {
|
||||||
Code int `json:"code"`
|
Code int `json:"code"`
|
||||||
Msg string `json:"msg"`
|
Msg string `json:"msg"`
|
||||||
Data any `json:"data"`
|
DetailMsg string `json:"detail_msg"`
|
||||||
|
Data any `json:"data"`
|
||||||
}
|
}
|
||||||
|
|
||||||
type CommonDtoFieldChoice struct {
|
type CommonDtoFieldChoice struct {
|
||||||
@ -51,3 +52,10 @@ type GetWhereCondition struct {
|
|||||||
Value1 any `json:"value1"`
|
Value1 any `json:"value1"`
|
||||||
Value2 any `json:"value2"`
|
Value2 any `json:"value2"`
|
||||||
}
|
}
|
||||||
|
|
||||||
|
type ItemInfo struct {
|
||||||
|
ItemID int `json:"item_id"`
|
||||||
|
ItemNum int64 `json:"item_num"`
|
||||||
|
ItemType int `json:"item_type"`
|
||||||
|
Desc string `json:"desc"`
|
||||||
|
}
|
||||||
|
@ -68,3 +68,37 @@ type CDKeyAddCountRsp struct {
|
|||||||
ID int `json:"id"`
|
ID int `json:"id"`
|
||||||
NewCount int `json:"new_count"`
|
NewCount int `json:"new_count"`
|
||||||
}
|
}
|
||||||
|
|
||||||
|
type CDKeyUseReq struct {
|
||||||
|
ProjectId int `json:"project_id"`
|
||||||
|
Key string `json:"key"`
|
||||||
|
Account string `json:"account"`
|
||||||
|
RoleID string `json:"role_id"`
|
||||||
|
RoleName string `json:"role_name"`
|
||||||
|
IP string `json:"ip"`
|
||||||
|
ServerID string `json:"server_id"`
|
||||||
|
DeviceID string `json:"device_id"`
|
||||||
|
}
|
||||||
|
|
||||||
|
type CDKeyUseRsp struct {
|
||||||
|
RewardItems []*ItemInfo `json:"reward_items"`
|
||||||
|
}
|
||||||
|
|
||||||
|
type CDKeyUsedHistoryReq struct {
|
||||||
|
ID int `json:"id"`
|
||||||
|
}
|
||||||
|
|
||||||
|
type CDKeyUsedInfo struct {
|
||||||
|
ServerID string `json:"server_id"`
|
||||||
|
Account string `json:"account"`
|
||||||
|
RoleID string `json:"role_id"`
|
||||||
|
RoleName string `json:"role_name"`
|
||||||
|
Key string `json:"key"`
|
||||||
|
IP string `json:"ip"`
|
||||||
|
DeviceID string `json:"device_id"`
|
||||||
|
CreatedAt string `json:"created_at"`
|
||||||
|
}
|
||||||
|
|
||||||
|
type CDKeyUsedHistoryRsp struct {
|
||||||
|
List []*CDKeyUsedInfo `json:"list"`
|
||||||
|
}
|
||||||
|
@ -5,17 +5,27 @@ import (
|
|||||||
"admin/internal/context"
|
"admin/internal/context"
|
||||||
"bytes"
|
"bytes"
|
||||||
"fmt"
|
"fmt"
|
||||||
|
"strings"
|
||||||
)
|
)
|
||||||
|
|
||||||
func (ctl *controller) CDKeyExportFile(ctx *context.WebContext, params *dto.CDKeyExportFileReq, rsp *dto.NilRsp) error {
|
func (ctl *controller) CDKeyExportFile(ctx *context.WebContext, params *dto.CDKeyExportFileReq, rsp *dto.NilRsp) error {
|
||||||
et, keys, err := ctl.svc.GetCDKeyAllKeys(params.ID)
|
projectId := getCtxURIProjectId(ctx)
|
||||||
|
|
||||||
|
et, keys, err := ctl.svc.GetCDKeyAllKeys(projectId, params.ID)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
content := bytes.NewBuffer(nil)
|
content := bytes.NewBuffer(nil)
|
||||||
content.WriteString(fmt.Sprintf("礼包码描述:%s\n", et.GetName()))
|
content.WriteString(fmt.Sprintf("礼包码描述:%s\n", et.GetName()))
|
||||||
content.WriteString(fmt.Sprintf("礼包码数量:%v\n\n", et.GetCount()))
|
content.WriteString(fmt.Sprintf("礼包码数量:%v\n", et.GetCount()))
|
||||||
|
var itemStr = make([]string, 0, len(et.Po.Attach))
|
||||||
|
for _, item := range et.Po.Attach {
|
||||||
|
itemStr = append(itemStr, fmt.Sprintf("%v*%v", item.Desc, item.Num))
|
||||||
|
}
|
||||||
|
content.WriteString(fmt.Sprintf("礼包码道具:%v\n", strings.Join(itemStr, ",")))
|
||||||
|
|
||||||
|
content.WriteString("\n")
|
||||||
content.WriteString(fmt.Sprintf("礼包码列表:\n"))
|
content.WriteString(fmt.Sprintf("礼包码列表:\n"))
|
||||||
for _, key := range keys {
|
for _, key := range keys {
|
||||||
content.WriteString(fmt.Sprintf("%s\n", key))
|
content.WriteString(fmt.Sprintf("%s\n", key))
|
||||||
@ -27,10 +37,30 @@ func (ctl *controller) CDKeyExportFile(ctx *context.WebContext, params *dto.CDKe
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (ctl *controller) CDKeyAddCount(ctx *context.WebContext, params *dto.CDKeyAddCountReq, rsp *dto.CDKeyAddCountRsp) error {
|
func (ctl *controller) CDKeyAddCount(ctx *context.WebContext, params *dto.CDKeyAddCountReq, rsp *dto.CDKeyAddCountRsp) error {
|
||||||
newCount, err := ctl.svc.CDKeyAddCount(params.ID, params.AddCount)
|
projectId := getCtxURIProjectId(ctx)
|
||||||
|
newCount, err := ctl.svc.CDKeyAddCount(projectId, params.ID, params.AddCount)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
rsp.NewCount = newCount
|
rsp.NewCount = newCount
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (ctl *controller) CDKeyUse(ctx *context.WebContext, params *dto.CDKeyUseReq, rsp *dto.CDKeyUseRsp) error {
|
||||||
|
batchInfo, err := ctl.svc.CDKeyUse(params)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
rsp.RewardItems = batchInfo.RewardItemsView()
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (ctl *controller) CDKeyUsedHistory(ctx *context.WebContext, params *dto.CDKeyUsedHistoryReq, rsp *dto.CDKeyUsedHistoryRsp) error {
|
||||||
|
projectId := getCtxURIProjectId(ctx)
|
||||||
|
list, err := ctl.svc.CDKeyUsedHistoryList(projectId, params.ID)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
rsp.List = list
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
@ -5,35 +5,45 @@ import (
|
|||||||
"admin/lib/web"
|
"admin/lib/web"
|
||||||
)
|
)
|
||||||
|
|
||||||
func (srv *Server) Route(engine *web.Engine) {
|
func (srv *Server) Route(engine *web.Engine, sdkEngine *web.Engine) {
|
||||||
engine.Use(srv.CheckToken)
|
{ // gm后台内部路由
|
||||||
|
engine.Use(srv.CheckToken)
|
||||||
|
|
||||||
apiGroup := engine.Group("/api", "")
|
apiGroup := engine.Group("/api", "")
|
||||||
|
|
||||||
{
|
|
||||||
// 注册项目增删改查接口
|
|
||||||
projectGroup := apiGroup.Group("/"+consts.ResourcesName_Project, "项目")
|
|
||||||
projectGroup.Get("", "查看列表", consts.WebPathPermit_Read, srv.ctl.CommonList)
|
|
||||||
projectGroup.Post("", "新增", consts.WebPathPermit_Read, srv.ctl.CommonPost)
|
|
||||||
projectGroup.Put("", "编辑", consts.WebPathPermit_Read, srv.ctl.CommonPut)
|
|
||||||
projectGroup.Delete("", "删除", consts.WebPathPermit_Read, srv.ctl.CommonDelete)
|
|
||||||
|
|
||||||
// 注册项目之下其它所有资源通用增删改查接口
|
|
||||||
{
|
{
|
||||||
resourceUnderProjectGroup := projectGroup.Group("/:projectId/:resource", "")
|
// 注册项目增删改查接口
|
||||||
resourceUnderProjectGroup.Get("", "查看列表", consts.WebPathPermit_Read, srv.ctl.CommonList)
|
projectGroup := apiGroup.Group("/"+consts.ResourcesName_Project, "项目")
|
||||||
resourceUnderProjectGroup.Post("", "新增", consts.WebPathPermit_Read, srv.ctl.CommonPost)
|
projectGroup.Get("", "查看列表", consts.WebPathPermit_Read, srv.ctl.CommonList)
|
||||||
resourceUnderProjectGroup.Put("", "编辑", consts.WebPathPermit_Read, srv.ctl.CommonPut)
|
projectGroup.Post("", "新增", consts.WebPathPermit_Read, srv.ctl.CommonPost)
|
||||||
resourceUnderProjectGroup.Delete("", "删除", consts.WebPathPermit_Read, srv.ctl.CommonDelete)
|
projectGroup.Put("", "编辑", consts.WebPathPermit_Read, srv.ctl.CommonPut)
|
||||||
|
projectGroup.Delete("", "删除", consts.WebPathPermit_Read, srv.ctl.CommonDelete)
|
||||||
|
|
||||||
|
// 注册项目之下其它所有资源通用增删改查接口
|
||||||
|
{
|
||||||
|
resourceUnderProjectGroup := projectGroup.Group("/:projectId/:resource", "")
|
||||||
|
resourceUnderProjectGroup.Get("", "查看列表", consts.WebPathPermit_Read, srv.ctl.CommonList)
|
||||||
|
resourceUnderProjectGroup.Post("", "新增", consts.WebPathPermit_Read, srv.ctl.CommonPost)
|
||||||
|
resourceUnderProjectGroup.Put("", "编辑", consts.WebPathPermit_Read, srv.ctl.CommonPut)
|
||||||
|
resourceUnderProjectGroup.Delete("", "删除", consts.WebPathPermit_Read, srv.ctl.CommonDelete)
|
||||||
|
}
|
||||||
|
|
||||||
|
projectGroup.Get("/:projectId/items", "获取项目所有道具列表", consts.WebPathPermit_Read, srv.ctl.GetProjectAllItems)
|
||||||
|
|
||||||
|
{
|
||||||
|
// 礼包码特殊接口
|
||||||
|
cdkeyGroup := projectGroup.Group("/:projectId/cdkey/special", "")
|
||||||
|
cdkeyGroup.Get("/add_count", "礼包码数量追加", consts.WebPathPermit_Write, srv.ctl.CDKeyAddCount)
|
||||||
|
cdkeyGroup.Get("/export", "导出礼包码文件", consts.WebPathPermit_Write, srv.ctl.CDKeyExportFile)
|
||||||
|
cdkeyGroup.Get("/used", "查看礼包码使用情况", consts.WebPathPermit_Write, srv.ctl.CDKeyUsedHistory)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
projectGroup.Get("/:projectId/items", "获取项目所有道具列表", consts.WebPathPermit_Read, srv.ctl.GetProjectAllItems)
|
{ // gm后台作为sdk,供内部其它游戏调用的路由
|
||||||
|
sdkGroup := sdkEngine.Group("/api", "")
|
||||||
{
|
{
|
||||||
// 礼包码特殊接口
|
sdkGroup.Get("/cdkey/use", "使用奖励码", consts.WebPathPermit_Write, srv.ctl.CDKeyUse)
|
||||||
cdkeyGroup := projectGroup.Group("/:projectId/cdkey/special", "")
|
|
||||||
cdkeyGroup.Get("/add_count", "礼包码数量追加", consts.WebPathPermit_Write, srv.ctl.CDKeyAddCount)
|
|
||||||
cdkeyGroup.Get("/export", "导出礼包码文件", consts.WebPathPermit_Write, srv.ctl.CDKeyExportFile)
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -2,11 +2,12 @@ package service
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"admin/apps/game/domain/entity"
|
"admin/apps/game/domain/entity"
|
||||||
|
"admin/apps/game/model/dto"
|
||||||
"admin/internal/errcode"
|
"admin/internal/errcode"
|
||||||
)
|
)
|
||||||
|
|
||||||
func (svc *Service) GetCDKeyAllKeys(id int) (*entity.CDKey, []string, error) {
|
func (svc *Service) GetCDKeyAllKeys(projectId int, id int) (*entity.CDKey, []string, error) {
|
||||||
et, find, err := svc.cdkeySvc.Get(id)
|
et, find, err := svc.cdkeySvc.Get(projectId, id)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, nil, err
|
return nil, nil, err
|
||||||
}
|
}
|
||||||
@ -16,6 +17,18 @@ func (svc *Service) GetCDKeyAllKeys(id int) (*entity.CDKey, []string, error) {
|
|||||||
return et, et.GenerateKeys(), nil
|
return et, et.GenerateKeys(), nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (svc *Service) CDKeyAddCount(id int, deltaCount int) (int, error) {
|
func (svc *Service) CDKeyAddCount(projectId int, id int, deltaCount int) (int, error) {
|
||||||
return svc.cdkeySvc.AddCount(id, deltaCount)
|
return svc.cdkeySvc.AddCount(projectId, id, deltaCount)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (svc *Service) CDKeyUse(params *dto.CDKeyUseReq) (*entity.CDKey, error) {
|
||||||
|
batchInfo, err := svc.cdkeySvc.CDKeyUse(params)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
return batchInfo, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (svc *Service) CDKeyUsedHistoryList(projectId, id int) ([]*dto.CDKeyUsedInfo, error) {
|
||||||
|
return svc.cdkeySvc.GetUsedHistoryList(projectId, id)
|
||||||
}
|
}
|
||||||
|
@ -11,3 +11,12 @@ const (
|
|||||||
NoPermission = 8 // 没有权限
|
NoPermission = 8 // 没有权限
|
||||||
ParamsInvalid = 9
|
ParamsInvalid = 9
|
||||||
)
|
)
|
||||||
|
|
||||||
|
// sdk系统错误码,给内部别的游戏调用api返回
|
||||||
|
// 错误码格式是系统号(100-999)*100 + 100 + 错误码自增
|
||||||
|
const (
|
||||||
|
CDKey_ = 100 // cdkey系统占用100
|
||||||
|
CDKeyInvalid = 100100 // cdkey无效
|
||||||
|
CDKeyAlreadyUsed = 100101 // cdkey已经使用过
|
||||||
|
CDKeyAlreadyExpired = 100102 // cdkey过期
|
||||||
|
)
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
package node
|
package node
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"admin/lib/web"
|
||||||
"admin/lib/xlog"
|
"admin/lib/xlog"
|
||||||
"fmt"
|
"fmt"
|
||||||
"github.com/gin-gonic/gin"
|
"github.com/gin-gonic/gin"
|
||||||
@ -51,8 +52,8 @@ func (app *Application) WithInitializeTask(desc string, task Task) *Application
|
|||||||
}
|
}
|
||||||
|
|
||||||
// WithServer 添加web服务器
|
// WithServer 添加web服务器
|
||||||
func (app *Application) WithServer(desc string, addr string) *gin.Engine {
|
func (app *Application) WithServer(desc string, addr string, newContextFun func(ctx *gin.Context) web.IContext) *web.Engine {
|
||||||
server := gin.Default()
|
server := web.New(newContextFun)
|
||||||
app.servers = append(app.servers, pair{desc, pair{addr, server}})
|
app.servers = append(app.servers, pair{desc, pair{addr, server}})
|
||||||
return server
|
return server
|
||||||
}
|
}
|
||||||
@ -144,7 +145,7 @@ func (app *Application) run() (err error) {
|
|||||||
for _, server := range app.servers {
|
for _, server := range app.servers {
|
||||||
go func(desc string, info pair) {
|
go func(desc string, info pair) {
|
||||||
addr := info.key.(string)
|
addr := info.key.(string)
|
||||||
engine := info.value.(*gin.Engine)
|
engine := info.value.(*web.Engine)
|
||||||
xlog.Noticef("app %v server %v will listen on %v", app.Name, desc, addr)
|
xlog.Noticef("app %v server %v will listen on %v", app.Name, desc, addr)
|
||||||
err := engine.Run(addr)
|
err := engine.Run(addr)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
0
admin/todo.md
Normal file
0
admin/todo.md
Normal file
BIN
admin/uniugm
BIN
admin/uniugm
Binary file not shown.
@ -1,5 +1,5 @@
|
|||||||
# ui
|
# ui
|
||||||
|
|
||||||
npm install --registry=https://registry.npmmirror.com
|
npm install --registry=https://registry.npmmirror.com
|
||||||
npm run dev
|
npm run dev
|
||||||
npm run build
|
npm run build
|
||||||
|
@ -8,4 +8,12 @@ export function cdkeyExport(baseUrl, params) {
|
|||||||
params: params,
|
params: params,
|
||||||
responseType: 'blob',
|
responseType: 'blob',
|
||||||
})
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
export function cdkeyUsed(baseUrl, params) {
|
||||||
|
return request({
|
||||||
|
url: baseUrl + '/special/used',
|
||||||
|
method: 'get',
|
||||||
|
params: params,
|
||||||
|
})
|
||||||
}
|
}
|
@ -6,7 +6,7 @@ import {useRoute} from 'vue-router';
|
|||||||
import LocalCache from "@/stores/localCache.js";
|
import LocalCache from "@/stores/localCache.js";
|
||||||
import empty from '@/components/restful/empty.vue';
|
import empty from '@/components/restful/empty.vue';
|
||||||
import {getWhereConditionDesc} from "@/utils/string.js";
|
import {getWhereConditionDesc} from "@/utils/string.js";
|
||||||
import {cdkeyExport} from "@/api/cdkey.js";
|
import {cdkeyExport, cdkeyUsed} from "@/api/cdkey.js";
|
||||||
|
|
||||||
const cachedResource = LocalCache.getCache("resource");
|
const cachedResource = LocalCache.getCache("resource");
|
||||||
|
|
||||||
@ -64,14 +64,14 @@ const listData = async () => {
|
|||||||
|
|
||||||
for (let i = 0; i < fieldsDescInfo.value.length; i++) {
|
for (let i = 0; i < fieldsDescInfo.value.length; i++) {
|
||||||
var field = fieldsDescInfo.value[i]
|
var field = fieldsDescInfo.value[i]
|
||||||
dialogAddForm.value[field.key] = ''
|
dialogObjectForm.value[field.key] = ''
|
||||||
|
|
||||||
if (field.required == true) {
|
if (field.required == true) {
|
||||||
rules.value[field.key] = [{required: true, message: field.name + "不能为空", trigger: "blur"}]
|
rules.value[field.key] = [{required: true, message: field.name + "不能为空", trigger: "blur"}]
|
||||||
}
|
}
|
||||||
|
|
||||||
if (field.type == "items") {
|
if (field.type == "items") {
|
||||||
dialogAddForm.value[field.key] = []
|
dialogObjectForm.value[field.key] = []
|
||||||
for (let j = 0; j < rows.value.length; j++) {
|
for (let j = 0; j < rows.value.length; j++) {
|
||||||
rows.value[j].jsonValue = JSON.stringify(rows.value[j][field.key])
|
rows.value[j].jsonValue = JSON.stringify(rows.value[j][field.key])
|
||||||
}
|
}
|
||||||
@ -128,22 +128,22 @@ onMounted(() => {
|
|||||||
const dialogAddVisible = ref(false)
|
const dialogAddVisible = ref(false)
|
||||||
const dialogLookVisible = ref(false)
|
const dialogLookVisible = ref(false)
|
||||||
const dialogEditVisible = ref(false)
|
const dialogEditVisible = ref(false)
|
||||||
|
const dialogUsedHistoryVisible = ref(false)
|
||||||
const dialogAddFormRef = ref(null)
|
const dialogAddFormRef = ref(null)
|
||||||
const dialogEditFormRef = ref(null)
|
const dialogEditFormRef = ref(null)
|
||||||
|
|
||||||
const dialogAddForm = ref({
|
const dialogObjectForm = ref({
|
||||||
ServerIDs: [],
|
ServerIDs: [],
|
||||||
Attach: [],
|
Attach: [],
|
||||||
})
|
})
|
||||||
const dialogEditForm = ref({})
|
|
||||||
|
|
||||||
|
|
||||||
const submitAdd = async () => {
|
const submitAdd = async () => {
|
||||||
try {
|
try {
|
||||||
await dialogAddFormRef.value.validate(valid => {
|
await dialogAddFormRef.value.validate(valid => {
|
||||||
if (valid) {
|
if (valid) {
|
||||||
console.log("commit add form:", dialogAddForm.value)
|
console.log("commit add form:", dialogObjectForm.value)
|
||||||
resourcePost(resource_url, dialogAddForm.value).then((res) => {
|
resourcePost(resource_url, dialogObjectForm.value).then((res) => {
|
||||||
ElNotification({
|
ElNotification({
|
||||||
title: "添加结果通知",
|
title: "添加结果通知",
|
||||||
message: "添加成功!",
|
message: "添加成功!",
|
||||||
@ -157,7 +157,7 @@ const submitAdd = async () => {
|
|||||||
}, (err) => {
|
}, (err) => {
|
||||||
console.log("添加报错:", err)
|
console.log("添加报错:", err)
|
||||||
})
|
})
|
||||||
console.log("提交数据:", dialogAddForm.value)
|
console.log("提交数据:", dialogObjectForm.value)
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
@ -169,7 +169,11 @@ const submitEdit = async () => {
|
|||||||
try {
|
try {
|
||||||
await dialogEditFormRef.value.validate(valid => {
|
await dialogEditFormRef.value.validate(valid => {
|
||||||
if (valid) {
|
if (valid) {
|
||||||
resourcePut(resource_url, dialogEditForm.value).then((res) => {
|
const oldIndex = dialogObjectForm.value.oldIndex
|
||||||
|
const oldData = dialogObjectForm.value.oldData
|
||||||
|
delete dialogObjectForm.value.oldIndex
|
||||||
|
delete dialogObjectForm.value.oldData
|
||||||
|
resourcePut(resource_url, dialogObjectForm.value).then((res) => {
|
||||||
ElNotification({
|
ElNotification({
|
||||||
title: "编辑结果通知",
|
title: "编辑结果通知",
|
||||||
message: "编辑成功!",
|
message: "编辑成功!",
|
||||||
@ -178,12 +182,12 @@ const submitEdit = async () => {
|
|||||||
"show-close": true,
|
"show-close": true,
|
||||||
})
|
})
|
||||||
dialogEditVisible.value = false
|
dialogEditVisible.value = false
|
||||||
rows.value[dialogEditForm.value.oldIndex] = res.data.dto
|
rows.value[oldIndex] = res.data.dto
|
||||||
handleCloseDialog()
|
handleCloseDialog()
|
||||||
}, (err) => {
|
}, (err) => {
|
||||||
console.log("添加报错:", err)
|
console.log("添加报错:", err)
|
||||||
})
|
})
|
||||||
console.log("提交数据:", dialogEditForm.value)
|
console.log("提交数据:", dialogObjectForm.value)
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
@ -220,23 +224,23 @@ const handleExport = (index, row) => {
|
|||||||
}
|
}
|
||||||
|
|
||||||
const handleLook = (index, row) => {
|
const handleLook = (index, row) => {
|
||||||
dialogEditForm.value.oldData = row
|
dialogObjectForm.value = row
|
||||||
dialogEditForm.value.oldIndex = index
|
dialogObjectForm.value.oldData = row
|
||||||
dialogEditForm.value = row
|
dialogObjectForm.value.oldIndex = index
|
||||||
console.log("look data:", row)
|
console.log("look data:", row)
|
||||||
dialogLookVisible.value = true
|
dialogLookVisible.value = true
|
||||||
}
|
}
|
||||||
|
|
||||||
const handleEdit = (index, row) => {
|
const handleEdit = (index, row) => {
|
||||||
dialogEditForm.value.oldData = row
|
dialogObjectForm.value = row
|
||||||
dialogEditForm.value.oldIndex = index
|
dialogObjectForm.value.oldData = row
|
||||||
dialogEditForm.value = row
|
dialogObjectForm.value.oldIndex = index
|
||||||
console.log("edit data:", row)
|
console.log("edit data:", row)
|
||||||
dialogEditVisible.value = true
|
dialogEditVisible.value = true
|
||||||
}
|
}
|
||||||
|
|
||||||
const handleDelete = (index, row) => {
|
const handleDelete = (index, row) => {
|
||||||
ElMessageBox.confirm("确定要删除吗?").then(() => {
|
ElMessageBox.confirm("请确认礼包码不会使用了,删除后发放的礼包码都会作废!!!!!确定要删除吗?").then(() => {
|
||||||
resourceDelete(resource_url, {id: row.ID}).then((res) => {
|
resourceDelete(resource_url, {id: row.ID}).then((res) => {
|
||||||
ElNotification({
|
ElNotification({
|
||||||
title: "删除结果通知",
|
title: "删除结果通知",
|
||||||
@ -268,16 +272,16 @@ function addItem() {
|
|||||||
|
|
||||||
console.log("add item:", d)
|
console.log("add item:", d)
|
||||||
|
|
||||||
if (typeof dialogAddForm.value.Attach === typeof "") {
|
if (typeof dialogObjectForm.value.Attach === typeof "") {
|
||||||
dialogAddForm.value.Attach = [];
|
dialogObjectForm.value.Attach = [];
|
||||||
}
|
}
|
||||||
dialogAddForm.value.Attach.push(d);
|
dialogObjectForm.value.Attach.push(d);
|
||||||
}
|
}
|
||||||
|
|
||||||
function deleteItem(row) {
|
function deleteItem(row) {
|
||||||
// 移除该对象
|
// 移除该对象
|
||||||
let number = form.value.Attach.findIndex(item => item === row);
|
let number = dialogObjectForm.value.Attach.findIndex(item => item === row);
|
||||||
dialogAddForm.value.Attach.splice(number, 1);
|
dialogObjectForm.value.Attach.splice(number, 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
const handleCloseDialog = () => {
|
const handleCloseDialog = () => {
|
||||||
@ -285,10 +289,11 @@ const handleCloseDialog = () => {
|
|||||||
dialogAddVisible.value = false
|
dialogAddVisible.value = false
|
||||||
dialogLookVisible.value = false
|
dialogLookVisible.value = false
|
||||||
dialogEditVisible.value = false
|
dialogEditVisible.value = false
|
||||||
dialogAddForm.value = {
|
dialogUsedHistoryVisible.value = false
|
||||||
|
dialogObjectForm.value = {
|
||||||
Attach: [],
|
Attach: [],
|
||||||
}
|
}
|
||||||
dialogEditForm.value = {}
|
item.value.desc = ''
|
||||||
}
|
}
|
||||||
|
|
||||||
const loadingRemoteItems = ref(false)
|
const loadingRemoteItems = ref(false)
|
||||||
@ -325,6 +330,18 @@ const resetConditionSearch = () => {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const cdkeyUsedHistoryList = ref([])
|
||||||
|
|
||||||
|
const handleGetUsedHistory = (index, row) => {
|
||||||
|
cdkeyUsed(resource_url, {id: row.ID}).then((res) => {
|
||||||
|
cdkeyUsedHistoryList.value = res.data.list
|
||||||
|
dialogObjectForm.value = row
|
||||||
|
dialogUsedHistoryVisible.value = true
|
||||||
|
}, (err) => {
|
||||||
|
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<template>
|
<template>
|
||||||
@ -400,9 +417,13 @@ const resetConditionSearch = () => {
|
|||||||
v-if="(resource_raw_node.meta.methods.put === true)">
|
v-if="(resource_raw_node.meta.methods.put === true)">
|
||||||
<span>修改</span>
|
<span>修改</span>
|
||||||
</el-button>
|
</el-button>
|
||||||
|
<el-button size="default" type="warning" @click="handleGetUsedHistory(scope.$index, scope.row)"
|
||||||
|
v-if="(resource_raw_node.meta.methods.put === true)">
|
||||||
|
<span>礼包使用</span>
|
||||||
|
</el-button>
|
||||||
<el-button size="default" type="danger" @click="handleDelete( scope.$index, scope.row)"
|
<el-button size="default" type="danger" @click="handleDelete( scope.$index, scope.row)"
|
||||||
v-if="(resource_raw_node.meta.methods.delete === true)">
|
v-if="(resource_raw_node.meta.methods.delete === true)">
|
||||||
<span>调试用</span>
|
<span>删除</span>
|
||||||
</el-button>
|
</el-button>
|
||||||
</template>
|
</template>
|
||||||
</el-table-column>
|
</el-table-column>
|
||||||
@ -422,7 +443,7 @@ const resetConditionSearch = () => {
|
|||||||
|
|
||||||
<el-dialog v-model="dialogAddVisible" :mask="true" title="添加" :modal="true" :before-close="handleCloseDialog"
|
<el-dialog v-model="dialogAddVisible" :mask="true" title="添加" :modal="true" :before-close="handleCloseDialog"
|
||||||
destroy-on-close>
|
destroy-on-close>
|
||||||
<el-form ref="dialogAddFormRef" :model="dialogAddForm" :rules="rules" label-position="right"
|
<el-form ref="dialogAddFormRef" :model="dialogObjectForm" :rules="rules" label-position="right"
|
||||||
label-width="130px">
|
label-width="130px">
|
||||||
<template v-for="fieldDescInfo in fieldsDescInfo">
|
<template v-for="fieldDescInfo in fieldsDescInfo">
|
||||||
<!--如何是items类型,就是物品下拉框+道具组合-->
|
<!--如何是items类型,就是物品下拉框+道具组合-->
|
||||||
@ -450,7 +471,7 @@ const resetConditionSearch = () => {
|
|||||||
</el-form-item>
|
</el-form-item>
|
||||||
</el-form>
|
</el-form>
|
||||||
<el-form-item label="奖励列表" prop="Attach">
|
<el-form-item label="奖励列表" prop="Attach">
|
||||||
<el-table :data="dialogAddForm.Attach" border>
|
<el-table :data="dialogObjectForm.Attach" border>
|
||||||
<el-table-column label="道具id" prop="id"/>
|
<el-table-column label="道具id" prop="id"/>
|
||||||
<el-table-column label="数量" prop="num"/>
|
<el-table-column label="数量" prop="num"/>
|
||||||
<el-table-column label="道具名" prop="desc"/>
|
<el-table-column label="道具名" prop="desc"/>
|
||||||
@ -469,7 +490,7 @@ const resetConditionSearch = () => {
|
|||||||
<el-form-item :label="fieldDescInfo.name" :prop="fieldDescInfo.key">
|
<el-form-item :label="fieldDescInfo.name" :prop="fieldDescInfo.key">
|
||||||
<el-tooltip effect="light" :content="fieldDescInfo.help_text" placement="bottom-start">
|
<el-tooltip effect="light" :content="fieldDescInfo.help_text" placement="bottom-start">
|
||||||
<el-select :placeholder="(fieldDescInfo.multi_choice === true ? '--多选--' : '--单选--')"
|
<el-select :placeholder="(fieldDescInfo.multi_choice === true ? '--多选--' : '--单选--')"
|
||||||
v-model="dialogAddForm[fieldDescInfo.key]" style="width: 150px"
|
v-model="dialogObjectForm[fieldDescInfo.key]" style="width: 150px"
|
||||||
:multiple="(fieldDescInfo.multi_choice === true)">
|
:multiple="(fieldDescInfo.multi_choice === true)">
|
||||||
<el-option v-for="info in fieldDescInfo.choices" :key="info.desc" :label="info.desc"
|
<el-option v-for="info in fieldDescInfo.choices" :key="info.desc" :label="info.desc"
|
||||||
:value="info.value"></el-option>
|
:value="info.value"></el-option>
|
||||||
@ -481,7 +502,7 @@ const resetConditionSearch = () => {
|
|||||||
<!-- 时间戳字段,展示时间选择器 -->
|
<!-- 时间戳字段,展示时间选择器 -->
|
||||||
<template v-else-if="(fieldDescInfo.type === 'Time')">
|
<template v-else-if="(fieldDescInfo.type === 'Time')">
|
||||||
<el-form-item :label="fieldDescInfo.name" :prop="fieldDescInfo.key">
|
<el-form-item :label="fieldDescInfo.name" :prop="fieldDescInfo.key">
|
||||||
<el-date-picker v-model="dialogAddForm[fieldDescInfo.key]" type="datetime"
|
<el-date-picker v-model="dialogObjectForm[fieldDescInfo.key]" type="datetime"
|
||||||
placeholder="选个时间" format="YYYY/MM/DD HH:mm:ss"
|
placeholder="选个时间" format="YYYY/MM/DD HH:mm:ss"
|
||||||
value-format="YYYY/MM/DD HH:mm:ss"></el-date-picker>
|
value-format="YYYY/MM/DD HH:mm:ss"></el-date-picker>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
@ -490,7 +511,7 @@ const resetConditionSearch = () => {
|
|||||||
<!-- 否则就是普通字段 -->
|
<!-- 否则就是普通字段 -->
|
||||||
<template v-else>
|
<template v-else>
|
||||||
<el-form-item :label="fieldDescInfo.name" :prop="fieldDescInfo.key">
|
<el-form-item :label="fieldDescInfo.name" :prop="fieldDescInfo.key">
|
||||||
<el-input v-model="dialogAddForm[fieldDescInfo.key]"
|
<el-input v-model="dialogObjectForm[fieldDescInfo.key]"
|
||||||
:placeholder="fieldDescInfo.help_text"></el-input>
|
:placeholder="fieldDescInfo.help_text"></el-input>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
</template>
|
</template>
|
||||||
@ -507,14 +528,14 @@ const resetConditionSearch = () => {
|
|||||||
|
|
||||||
<el-dialog v-model="dialogLookVisible" :mask="true" title="编辑" :modal="true" :before-close="handleCloseDialog"
|
<el-dialog v-model="dialogLookVisible" :mask="true" title="编辑" :modal="true" :before-close="handleCloseDialog"
|
||||||
destroy-on-close>
|
destroy-on-close>
|
||||||
<el-form ref="dialogEditFormRef" :model="dialogEditForm" :rules="rules" class="operation_form"
|
<el-form ref="dialogEditFormRef" :model="dialogObjectForm" :rules="rules" class="operation_form"
|
||||||
label-width="130px">
|
label-width="130px">
|
||||||
<template v-for="fieldDescInfo in fieldsDescInfo">
|
<template v-for="fieldDescInfo in fieldsDescInfo">
|
||||||
|
|
||||||
<!--如果是items类型,就是物品下拉框+道具组合-->
|
<!--如果是items类型,就是物品下拉框+道具组合-->
|
||||||
<template v-if="(fieldDescInfo.type === 'items')">
|
<template v-if="(fieldDescInfo.type === 'items')">
|
||||||
<el-form-item label="奖励列表" prop="attachmentsList">
|
<el-form-item label="奖励列表" prop="attachmentsList">
|
||||||
<el-table :data="dialogEditForm.Attach" border>
|
<el-table :data="dialogObjectForm.Attach" border>
|
||||||
<el-table-column label="道具id" prop="id"/>
|
<el-table-column label="道具id" prop="id"/>
|
||||||
<el-table-column label="数量" prop="num"/>
|
<el-table-column label="数量" prop="num"/>
|
||||||
<el-table-column label="道具名" prop="desc"/>
|
<el-table-column label="道具名" prop="desc"/>
|
||||||
@ -529,7 +550,7 @@ const resetConditionSearch = () => {
|
|||||||
<el-tooltip effect="light" :content="fieldDescInfo.help_text" placement="bottom-start">
|
<el-tooltip effect="light" :content="fieldDescInfo.help_text" placement="bottom-start">
|
||||||
<el-select :placeholder="(fieldDescInfo.multi_choice === true ? '--多选--' : '--单选--')"
|
<el-select :placeholder="(fieldDescInfo.multi_choice === true ? '--多选--' : '--单选--')"
|
||||||
disabled
|
disabled
|
||||||
v-model="dialogEditForm[fieldDescInfo.key]" style="width: 150px"
|
v-model="dialogObjectForm[fieldDescInfo.key]" style="width: 150px"
|
||||||
:multiple="(fieldDescInfo.multi_choice === true)">
|
:multiple="(fieldDescInfo.multi_choice === true)">
|
||||||
<el-option v-for="info in fieldDescInfo.choices" :key="info.desc" :label="info.desc"
|
<el-option v-for="info in fieldDescInfo.choices" :key="info.desc" :label="info.desc"
|
||||||
:value="info.value"></el-option>
|
:value="info.value"></el-option>
|
||||||
@ -541,9 +562,9 @@ const resetConditionSearch = () => {
|
|||||||
<!-- 时间戳字段,展示时间选择器 -->
|
<!-- 时间戳字段,展示时间选择器 -->
|
||||||
<template v-else-if="(fieldDescInfo.type === 'Time')">
|
<template v-else-if="(fieldDescInfo.type === 'Time')">
|
||||||
<el-form-item :label="fieldDescInfo.name" :prop="fieldDescInfo.key">
|
<el-form-item :label="fieldDescInfo.name" :prop="fieldDescInfo.key">
|
||||||
<el-date-picker v-model="dialogEditForm[fieldDescInfo.key]" type="datetime"
|
<el-date-picker v-model="dialogObjectForm[fieldDescInfo.key]" type="datetime"
|
||||||
disabled
|
disabled
|
||||||
placeholder="选个时间" format="YYYY/MM/DD HH:mm:ss"
|
placeholder="空时间" format="YYYY/MM/DD HH:mm:ss"
|
||||||
value-format="YYYY/MM/DD HH:mm:ss"></el-date-picker>
|
value-format="YYYY/MM/DD HH:mm:ss"></el-date-picker>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
</template>
|
</template>
|
||||||
@ -551,9 +572,8 @@ const resetConditionSearch = () => {
|
|||||||
<!-- 否则就是普通字段 -->
|
<!-- 否则就是普通字段 -->
|
||||||
<template v-else>
|
<template v-else>
|
||||||
<el-form-item :label="fieldDescInfo.name" :prop="fieldDescInfo.key">
|
<el-form-item :label="fieldDescInfo.name" :prop="fieldDescInfo.key">
|
||||||
<el-input v-model="dialogEditForm[fieldDescInfo.key]"
|
<el-input v-model="dialogObjectForm[fieldDescInfo.key]"
|
||||||
disabled
|
disabled></el-input>
|
||||||
:placeholder="fieldDescInfo.help_text"></el-input>
|
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
</template>
|
</template>
|
||||||
</template>
|
</template>
|
||||||
@ -571,7 +591,7 @@ const resetConditionSearch = () => {
|
|||||||
|
|
||||||
<el-dialog v-model="dialogEditVisible" :mask="true" title="编辑" :modal="true" :before-close="handleCloseDialog"
|
<el-dialog v-model="dialogEditVisible" :mask="true" title="编辑" :modal="true" :before-close="handleCloseDialog"
|
||||||
destroy-on-close>
|
destroy-on-close>
|
||||||
<el-form ref="dialogEditFormRef" :model="dialogEditForm" :rules="rules" class="operation_form"
|
<el-form ref="dialogEditFormRef" :model="dialogObjectForm" :rules="rules" class="operation_form"
|
||||||
label-width="130px">
|
label-width="130px">
|
||||||
<template v-for="fieldDescInfo in fieldsDescInfo">
|
<template v-for="fieldDescInfo in fieldsDescInfo">
|
||||||
|
|
||||||
@ -581,10 +601,15 @@ const resetConditionSearch = () => {
|
|||||||
label-width="130px">
|
label-width="130px">
|
||||||
<el-form-item :label="fieldDescInfo.name" :prop="fieldDescInfo.key">
|
<el-form-item :label="fieldDescInfo.name" :prop="fieldDescInfo.key">
|
||||||
<el-tooltip effect="light" :content="fieldDescInfo.help_text" placement="bottom-start">
|
<el-tooltip effect="light" :content="fieldDescInfo.help_text" placement="bottom-start">
|
||||||
<el-select placeholder="--搜索道具--" v-model="item.id" style="width: 150px"
|
<el-select placeholder="--搜索道具--" v-model="item" style="width: 150px"
|
||||||
filterable remote :remote-method="handleQueryItem" :loading="loadingRemoteItems">
|
filterable remote
|
||||||
|
:remote-method="handleQueryItem"
|
||||||
|
:loading="loadingRemoteItems"
|
||||||
|
value-key="value"
|
||||||
|
@change="handleItemOnSelect"
|
||||||
|
>
|
||||||
<el-option v-for="info in itemChoices" :key="info.value" :label="info.desc"
|
<el-option v-for="info in itemChoices" :key="info.value" :label="info.desc"
|
||||||
:value="info.value"></el-option>
|
:value="info"></el-option>
|
||||||
</el-select>
|
</el-select>
|
||||||
</el-tooltip>
|
</el-tooltip>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
@ -596,7 +621,7 @@ const resetConditionSearch = () => {
|
|||||||
</el-form-item>
|
</el-form-item>
|
||||||
</el-form>
|
</el-form>
|
||||||
<el-form-item label="奖励列表" prop="attachmentsList">
|
<el-form-item label="奖励列表" prop="attachmentsList">
|
||||||
<el-table :data="dialogEditForm.Attach" border>
|
<el-table :data="dialogObjectForm.Attach" border>
|
||||||
<el-table-column label="道具id" prop="id"/>
|
<el-table-column label="道具id" prop="id"/>
|
||||||
<el-table-column label="数量" prop="num"/>
|
<el-table-column label="数量" prop="num"/>
|
||||||
<el-table-column label="道具名" prop="desc"/>
|
<el-table-column label="道具名" prop="desc"/>
|
||||||
@ -616,7 +641,7 @@ const resetConditionSearch = () => {
|
|||||||
<el-form-item :label="fieldDescInfo.name" :prop="fieldDescInfo.key">
|
<el-form-item :label="fieldDescInfo.name" :prop="fieldDescInfo.key">
|
||||||
<el-tooltip effect="light" :content="fieldDescInfo.help_text" placement="bottom-start">
|
<el-tooltip effect="light" :content="fieldDescInfo.help_text" placement="bottom-start">
|
||||||
<el-select :placeholder="(fieldDescInfo.multi_choice === true ? '--多选--' : '--单选--')"
|
<el-select :placeholder="(fieldDescInfo.multi_choice === true ? '--多选--' : '--单选--')"
|
||||||
v-model="dialogEditForm[fieldDescInfo.key]" style="width: 150px"
|
v-model="dialogObjectForm[fieldDescInfo.key]" style="width: 150px"
|
||||||
:multiple="(fieldDescInfo.multi_choice === true)">
|
:multiple="(fieldDescInfo.multi_choice === true)">
|
||||||
<el-option v-for="info in fieldDescInfo.choices" :key="info.desc" :label="info.desc"
|
<el-option v-for="info in fieldDescInfo.choices" :key="info.desc" :label="info.desc"
|
||||||
:value="info.value"></el-option>
|
:value="info.value"></el-option>
|
||||||
@ -628,7 +653,7 @@ const resetConditionSearch = () => {
|
|||||||
<!-- 时间戳字段,展示时间选择器 -->
|
<!-- 时间戳字段,展示时间选择器 -->
|
||||||
<template v-else-if="(fieldDescInfo.type === 'Time')">
|
<template v-else-if="(fieldDescInfo.type === 'Time')">
|
||||||
<el-form-item :label="fieldDescInfo.name" :prop="fieldDescInfo.key">
|
<el-form-item :label="fieldDescInfo.name" :prop="fieldDescInfo.key">
|
||||||
<el-date-picker v-model="dialogEditForm[fieldDescInfo.key]" type="datetime"
|
<el-date-picker v-model="dialogObjectForm[fieldDescInfo.key]" type="datetime"
|
||||||
placeholder="选个时间" format="YYYY/MM/DD HH:mm:ss"
|
placeholder="选个时间" format="YYYY/MM/DD HH:mm:ss"
|
||||||
value-format="YYYY/MM/DD HH:mm:ss"></el-date-picker>
|
value-format="YYYY/MM/DD HH:mm:ss"></el-date-picker>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
@ -637,7 +662,7 @@ const resetConditionSearch = () => {
|
|||||||
<!-- 否则就是普通字段 -->
|
<!-- 否则就是普通字段 -->
|
||||||
<template v-else>
|
<template v-else>
|
||||||
<el-form-item :label="fieldDescInfo.name" :prop="fieldDescInfo.key">
|
<el-form-item :label="fieldDescInfo.name" :prop="fieldDescInfo.key">
|
||||||
<el-input v-model="dialogEditForm[fieldDescInfo.key]"
|
<el-input v-model="dialogObjectForm[fieldDescInfo.key]"
|
||||||
:placeholder="fieldDescInfo.help_text"></el-input>
|
:placeholder="fieldDescInfo.help_text"></el-input>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
</template>
|
</template>
|
||||||
@ -645,7 +670,7 @@ const resetConditionSearch = () => {
|
|||||||
|
|
||||||
<template v-else>
|
<template v-else>
|
||||||
<el-form-item :label="fieldDescInfo.name" :prop="fieldDescInfo.key">
|
<el-form-item :label="fieldDescInfo.name" :prop="fieldDescInfo.key">
|
||||||
<el-input v-model="dialogEditForm[fieldDescInfo.key]"
|
<el-input v-model="dialogObjectForm[fieldDescInfo.key]"
|
||||||
:placeholder="fieldDescInfo.help_text" disabled></el-input>
|
:placeholder="fieldDescInfo.help_text" disabled></el-input>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
</template>
|
</template>
|
||||||
@ -663,6 +688,33 @@ const resetConditionSearch = () => {
|
|||||||
</el-form>
|
</el-form>
|
||||||
</el-dialog>
|
</el-dialog>
|
||||||
|
|
||||||
|
<el-dialog v-model="dialogUsedHistoryVisible" :mask="true"
|
||||||
|
:modal="true"
|
||||||
|
:before-close="handleCloseDialog"
|
||||||
|
destroy-on-close>
|
||||||
|
<template #header>
|
||||||
|
<span style="font-size: 30px" v-if="dialogObjectForm.CodeType === 0">
|
||||||
|
{{ dialogObjectForm.Name }}-{{ dialogObjectForm.Code }}:使用{{ cdkeyUsedHistoryList.length }}个
|
||||||
|
</span>
|
||||||
|
<span style="font-size: 30px" v-if="dialogObjectForm.CodeType === 1">
|
||||||
|
{{ dialogObjectForm.Name }}-{{ dialogObjectForm.CodeNum }}个:使用{{
|
||||||
|
cdkeyUsedHistoryList.length
|
||||||
|
}}个
|
||||||
|
</span>
|
||||||
|
</template>
|
||||||
|
<el-table :data="cdkeyUsedHistoryList" style="width: 100%" height="300" max-height="300" table-layout="auto"
|
||||||
|
stripe>
|
||||||
|
<el-table-column prop="server_id" label="区服"></el-table-column>
|
||||||
|
<el-table-column prop="account" label="账号名"></el-table-column>
|
||||||
|
<el-table-column prop="role_id" label="角色id"></el-table-column>
|
||||||
|
<el-table-column prop="role_name" label="角色名"></el-table-column>
|
||||||
|
<el-table-column prop="key" label="码"></el-table-column>
|
||||||
|
<el-table-column prop="ip" label="ip"></el-table-column>
|
||||||
|
<el-table-column prop="device_id" label="设备号"></el-table-column>
|
||||||
|
<el-table-column prop="created_at" label="使用时间"></el-table-column>
|
||||||
|
</el-table>
|
||||||
|
</el-dialog>
|
||||||
|
|
||||||
</el-main>
|
</el-main>
|
||||||
</el-container>
|
</el-container>
|
||||||
</template>
|
</template>
|
||||||
|
Loading…
x
Reference in New Issue
Block a user