处理分享
This commit is contained in:
parent
ba6dbcc2c7
commit
c209dafac5
@ -8,7 +8,6 @@ import (
|
|||||||
"knowledge/api/responses"
|
"knowledge/api/responses"
|
||||||
"knowledge/global"
|
"knowledge/global"
|
||||||
"knowledge/utils"
|
"knowledge/utils"
|
||||||
"sort"
|
|
||||||
"time"
|
"time"
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -32,7 +31,6 @@ func (r *Share) GetShare(c *gin.Context) {
|
|||||||
// 业务处理
|
// 业务处理
|
||||||
questionQaDao := dao.QuestionQaDao{}
|
questionQaDao := dao.QuestionQaDao{}
|
||||||
questionQaItemDao := dao.QuestionQaItemDao{}
|
questionQaItemDao := dao.QuestionQaItemDao{}
|
||||||
questionDao := dao.QuestionDao{}
|
|
||||||
|
|
||||||
// 获取题库数据
|
// 获取题库数据
|
||||||
maps := make(map[string]interface{})
|
maps := make(map[string]interface{})
|
||||||
@ -70,27 +68,18 @@ func (r *Share) GetShare(c *gin.Context) {
|
|||||||
maps = make(map[string]interface{})
|
maps = make(map[string]interface{})
|
||||||
maps["qa_id"] = questionQa.QaId
|
maps["qa_id"] = questionQa.QaId
|
||||||
maps["is_must_select"] = 1
|
maps["is_must_select"] = 1
|
||||||
questionQaItems, err := questionQaItemDao.GetQuestionQaItemList(maps)
|
questionQaItems, err := questionQaItemDao.GetQuestionQaItemrPreloadList(maps)
|
||||||
if err == nil && len(questionQaItems) > 0 {
|
if err == nil && len(questionQaItems) > 0 {
|
||||||
shareQuestionDtos := make([]*dto.ShareQuestionDto, len(questionQaItems))
|
|
||||||
|
|
||||||
for i, item := range questionQaItems {
|
for i, item := range questionQaItems {
|
||||||
// 获取题目数据
|
// 处理返回值
|
||||||
question, err := questionDao.GetQuestionById(item.QuestionId)
|
questionDto := dto.GetShareQuestionDto(item.Question)
|
||||||
if err != nil {
|
|
||||||
responses.FailWithMessage("题目错误", c)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
shareQuestionDto := dto.GetShareQuestionDto(question)
|
// 加载选项
|
||||||
|
questionDto.LoadQuestionOption(item.Question.QuestionOption)
|
||||||
shareQuestionDto.IsMustSelect = item.IsMustSelect
|
|
||||||
|
|
||||||
// 将转换后的结构体添加到新切片中
|
// 将转换后的结构体添加到新切片中
|
||||||
shareQuestionDtos[i] = shareQuestionDto
|
g.Question[i] = questionDto
|
||||||
}
|
}
|
||||||
|
|
||||||
g.Question = shareQuestionDtos
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// 题目数据-剩余随机数量
|
// 题目数据-剩余随机数量
|
||||||
@ -100,30 +89,58 @@ func (r *Share) GetShare(c *gin.Context) {
|
|||||||
maps = make(map[string]interface{})
|
maps = make(map[string]interface{})
|
||||||
maps["qa_id"] = questionQa.QaId
|
maps["qa_id"] = questionQa.QaId
|
||||||
maps["is_must_select"] = 0
|
maps["is_must_select"] = 0
|
||||||
questionQaItems, err = questionQaItemDao.GetQuestionQaItemListRand(maps, remainingQuantity)
|
questionQaItems, err = questionQaItemDao.GetQuestionQaItemWhereListRand(maps, remainingQuantity)
|
||||||
if err == nil && len(questionQaItems) > 0 {
|
if err == nil && len(questionQaItems) > 0 {
|
||||||
for _, item := range questionQaItems {
|
for _, item := range questionQaItems {
|
||||||
// 获取题目数据
|
// 处理返回值
|
||||||
question, err := questionDao.GetQuestionById(item.QuestionId)
|
questionDto := dto.GetShareQuestionDto(item.Question)
|
||||||
if err != nil {
|
|
||||||
responses.FailWithMessage("题目错误", c)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
shareQuestionDto := dto.GetShareQuestionDto(question)
|
// 加载选项
|
||||||
|
questionDto.LoadQuestionOption(item.Question.QuestionOption)
|
||||||
shareQuestionDto.IsMustSelect = item.IsMustSelect
|
|
||||||
|
|
||||||
// 将转换后的结构体添加到新切片中
|
// 将转换后的结构体添加到新切片中
|
||||||
g.Question = append(g.Question, shareQuestionDto)
|
g.Question = append(g.Question, questionDto)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// 按照难度重新排序题目顺序
|
// 按照难度重新排序题目顺序
|
||||||
sort.SliceStable(g.Question, func(i, j int) bool {
|
//sort.SliceStable(g.Question, func(i, j int) bool {
|
||||||
return g.Question[i].Difficulty < g.Question[j].Difficulty
|
// return g.Question[i].Difficulty < g.Question[j].Difficulty
|
||||||
})
|
//})
|
||||||
|
|
||||||
|
// 加载飞花令
|
||||||
|
if questionQa.QaDisplayType == 2 {
|
||||||
|
questionQaTokenDao := dao.QuestionQaTokenDao{}
|
||||||
|
maps = make(map[string]interface{})
|
||||||
|
maps["qa_id"] = questionQa.QaId
|
||||||
|
questionQaToken, err := questionQaTokenDao.GetQuestionQaTokenList(maps)
|
||||||
|
if err != nil {
|
||||||
|
responses.FailWithMessage("内部错误", c)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
baseTokenItemDao := dao.BaseTokenItemDao{}
|
||||||
|
for _, v := range questionQaToken {
|
||||||
|
// 加载详细飞花令
|
||||||
|
baseTokenItem, err := baseTokenItemDao.GetBaseTokenItemPreloadOrderByTokenId(v.TokenId)
|
||||||
|
if err != nil {
|
||||||
|
responses.FailWithMessage("内部错误", c)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
// 处理返回值
|
||||||
|
for _, item := range baseTokenItem {
|
||||||
|
if len(g.BaseTokenItem) < questionQa.QaQuantity {
|
||||||
|
// 处理返回值
|
||||||
|
baseTokenItemDto := dto.GetBaseTokenItemDto(item)
|
||||||
|
|
||||||
|
// 将转换后的结构体添加到新切片中
|
||||||
|
g.BaseTokenItem = append(g.BaseTokenItem, baseTokenItemDto)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
responses.OkWithData(g, c)
|
responses.OkWithData(g, c)
|
||||||
}
|
}
|
||||||
|
|||||||
@ -29,6 +29,18 @@ func (r *BaseTokenItemDao) GetBaseTokenItemPreloadById(ItemId int64) (m *model.B
|
|||||||
return m, nil
|
return m, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// GetBaseTokenItemPreloadOrderByTokenId 获取数据-加载全部关联-排序-TokenId
|
||||||
|
func (r *BaseTokenItemDao) GetBaseTokenItemPreloadOrderByTokenId(tokenId int64) (m []*model.BaseTokenItem, err error) {
|
||||||
|
err = global.Db.Where("token_id = ?", tokenId).
|
||||||
|
Order("item_sort desc").
|
||||||
|
Order("created_at desc").
|
||||||
|
Find(&m).Error
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
return m, nil
|
||||||
|
}
|
||||||
|
|
||||||
// DeleteBaseTokenItem 删除
|
// DeleteBaseTokenItem 删除
|
||||||
func (r *BaseTokenItemDao) DeleteBaseTokenItem(tx *gorm.DB, maps interface{}) error {
|
func (r *BaseTokenItemDao) DeleteBaseTokenItem(tx *gorm.DB, maps interface{}) error {
|
||||||
err := tx.Where(maps).Delete(&model.BaseTokenItem{}).Error
|
err := tx.Where(maps).Delete(&model.BaseTokenItem{}).Error
|
||||||
|
|||||||
@ -3,6 +3,7 @@ package dao
|
|||||||
import (
|
import (
|
||||||
"errors"
|
"errors"
|
||||||
"gorm.io/gorm"
|
"gorm.io/gorm"
|
||||||
|
"gorm.io/gorm/clause"
|
||||||
"knowledge/api/model"
|
"knowledge/api/model"
|
||||||
"knowledge/api/requests"
|
"knowledge/api/requests"
|
||||||
"knowledge/global"
|
"knowledge/global"
|
||||||
@ -81,6 +82,15 @@ func (r *QuestionQaItemDao) GetQuestionQaItemList(maps interface{}) (m []*model.
|
|||||||
return m, nil
|
return m, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// GetQuestionQaItemrPreloadList 获取列表-加载全部关联
|
||||||
|
func (r *QuestionQaItemDao) GetQuestionQaItemrPreloadList(maps interface{}) (m []*model.QuestionQaItem, err error) {
|
||||||
|
err = global.Db.Preload(clause.Associations).Where(maps).Find(&m).Error
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
return m, nil
|
||||||
|
}
|
||||||
|
|
||||||
// GetQuestionQaItemListRand 获取列表-随机
|
// GetQuestionQaItemListRand 获取列表-随机
|
||||||
func (r *QuestionQaItemDao) GetQuestionQaItemListRand(maps interface{}, limit int) (m []*model.QuestionQaItem, err error) {
|
func (r *QuestionQaItemDao) GetQuestionQaItemListRand(maps interface{}, limit int) (m []*model.QuestionQaItem, err error) {
|
||||||
err = global.Db.Where(maps).Limit(limit).Order("rand()").Find(&m).Error
|
err = global.Db.Where(maps).Limit(limit).Order("rand()").Find(&m).Error
|
||||||
@ -221,3 +231,39 @@ func (r *QuestionQaItemDao) GetQuestionQaItemPageSearch(req requests.GetQuestion
|
|||||||
}
|
}
|
||||||
return m, totalRecords, nil
|
return m, totalRecords, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// GetQuestionQaItemWhereListRand 获取列表-随机
|
||||||
|
func (r *QuestionQaItemDao) GetQuestionQaItemWhereListRand(maps interface{}, limit int) (m []*model.QuestionQaItem, err error) {
|
||||||
|
query := global.Db.Model(&model.QuestionQaItem{})
|
||||||
|
query = query.Where(maps)
|
||||||
|
|
||||||
|
query = query.Preload("Question")
|
||||||
|
|
||||||
|
// 选项
|
||||||
|
query = query.Preload("Question.QuestionOption")
|
||||||
|
|
||||||
|
subQuery := global.Db.Model(&model.Question{}).
|
||||||
|
Select("question_id").
|
||||||
|
Where("question_status = ?", 1).
|
||||||
|
Where("is_delete = ?", 0)
|
||||||
|
|
||||||
|
query = query.Where(gorm.Expr("question_id IN (?)", subQuery))
|
||||||
|
|
||||||
|
query = query.Limit(limit).Order("rand()")
|
||||||
|
|
||||||
|
err = query.Find(&m).Error
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
return m, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
//subQuery := global.Db.Model(&model.Question{}).
|
||||||
|
//Where("kb_question.question_id = kb_question_qa_item.question_id").
|
||||||
|
//Where("question_status = ?", 1).
|
||||||
|
//Where("is_delete = ?", 0).
|
||||||
|
//Select("1")
|
||||||
|
//
|
||||||
|
//query = query.Where("EXISTS (?)", subQuery)
|
||||||
|
//
|
||||||
|
//query = query.Limit(limit).Order("rand()")
|
||||||
|
|||||||
@ -72,6 +72,15 @@ func (r *QuestionQaTokenDao) GetQuestionQaTokenList(maps interface{}) (m []*mode
|
|||||||
return m, nil
|
return m, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// GetQuestionQaTokenPreloadList 获取列表-加载全部关联
|
||||||
|
func (r *QuestionQaTokenDao) GetQuestionQaTokenPreloadList(maps interface{}) (m []*model.QuestionQaToken, err error) {
|
||||||
|
err = global.Db.Preload(clause.Associations).Where(maps).Find(&m).Error
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
return m, nil
|
||||||
|
}
|
||||||
|
|
||||||
// GetQuestionQaTokenCount 获取数量
|
// GetQuestionQaTokenCount 获取数量
|
||||||
func (r *QuestionQaTokenDao) GetQuestionQaTokenCount(maps interface{}) (total int64, err error) {
|
func (r *QuestionQaTokenDao) GetQuestionQaTokenCount(maps interface{}) (total int64, err error) {
|
||||||
err = global.Db.Model(&model.QuestionQaToken{}).Where(maps).Count(&total).Error
|
err = global.Db.Model(&model.QuestionQaToken{}).Where(maps).Count(&total).Error
|
||||||
|
|||||||
@ -112,6 +112,32 @@ func GetQuestionListDto(m []*model.Question) []*QuestionDto {
|
|||||||
return responses
|
return responses
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// GetShareQuestionDto 题目详情-分享
|
||||||
|
func GetShareQuestionDto(m *model.Question) *QuestionDto {
|
||||||
|
var questionImage []string
|
||||||
|
if m.QuestionImage != "" {
|
||||||
|
result := strings.Split(m.QuestionImage, ",")
|
||||||
|
if len(result) > 0 {
|
||||||
|
for _, v := range result {
|
||||||
|
v = utils.AddOssDomain(v)
|
||||||
|
questionImage = append(questionImage, v)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return &QuestionDto{
|
||||||
|
QuestionId: fmt.Sprintf("%d", m.QuestionId),
|
||||||
|
QuestionName: m.QuestionName,
|
||||||
|
QuestionType: m.QuestionType,
|
||||||
|
QuestionSource: m.QuestionSource,
|
||||||
|
QuestionImage: questionImage,
|
||||||
|
QuestionAnalysis: m.QuestionAnalysis,
|
||||||
|
Difficulty: m.Difficulty,
|
||||||
|
CreatedAt: m.CreatedAt,
|
||||||
|
UpdatedAt: m.UpdatedAt,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// LoadFirstLabel 加载一级标签
|
// LoadFirstLabel 加载一级标签
|
||||||
func (r *QuestionDto) LoadFirstLabel(m *model.Label) *QuestionDto {
|
func (r *QuestionDto) LoadFirstLabel(m *model.Label) *QuestionDto {
|
||||||
if m != nil {
|
if m != nil {
|
||||||
|
|||||||
@ -2,50 +2,49 @@ package dto
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"knowledge/api/model"
|
"knowledge/api/model"
|
||||||
"knowledge/utils"
|
|
||||||
"strings"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
type ShareDto struct {
|
type ShareDto struct {
|
||||||
QuestionQa *QuestionQaDto `json:"question_qa"` // 题库数据
|
QuestionQa *QuestionQaDto `json:"question_qa"` // 题库数据
|
||||||
Question []*ShareQuestionDto `json:"question"` // 题目数据
|
Question []*QuestionDto `json:"question"` // 题库关联题目列表
|
||||||
|
BaseTokenItem []*BaseTokenItemDto `json:"base_token_item"` // 题库关联飞花令-列表
|
||||||
}
|
}
|
||||||
|
|
||||||
// ShareQuestionDto 题目数据
|
//// ShareQuestionDto 题目数据
|
||||||
type ShareQuestionDto struct {
|
//type ShareQuestionDto struct {
|
||||||
QuestionName string `json:"question_name"` // 题目名称
|
// QuestionName string `json:"question_name"` // 题目名称
|
||||||
QuestionType int `json:"question_type"` // 题目类型(1:单选 2:多选 3:问答 4:判断)
|
// QuestionType int `json:"question_type"` // 题目类型(1:单选 2:多选 3:问答 4:判断)
|
||||||
QuestionSource int `json:"question_source"` // 题目来源(1:本题库 2:外部数据)
|
// QuestionSource int `json:"question_source"` // 题目来源(1:本题库 2:外部数据)
|
||||||
QuestionImage []string `json:"question_image"` // 题目图片
|
// QuestionImage []string `json:"question_image"` // 题目图片
|
||||||
QuestionAnswer string `json:"question_answer"` // 答案
|
// QuestionAnswer string `json:"question_answer"` // 答案
|
||||||
QuestionAnalysis string `json:"question_analysis"` // 解析
|
// QuestionAnalysis string `json:"question_analysis"` // 解析
|
||||||
Difficulty int `json:"difficulty"` // 难度(0:未知 1:低 2:中 3:高)
|
// Difficulty int `json:"difficulty"` // 难度(0:未知 1:低 2:中 3:高)
|
||||||
IsMustSelect int `json:"is_must_select"` // 是否必被选中
|
// IsMustSelect int `json:"is_must_select"` // 是否必被选中
|
||||||
}
|
//}
|
||||||
|
//
|
||||||
// GetShareQuestionDto 分享题目详情
|
//// GetShareQuestionDto 分享题目详情
|
||||||
func GetShareQuestionDto(m *model.Question) *ShareQuestionDto {
|
//func GetShareQuestionDto(m *model.Question) *ShareQuestionDto {
|
||||||
var questionImage []string
|
// var questionImage []string
|
||||||
if m.QuestionImage != "" {
|
// if m.QuestionImage != "" {
|
||||||
result := strings.Split(m.QuestionImage, ",")
|
// result := strings.Split(m.QuestionImage, ",")
|
||||||
if len(result) > 0 {
|
// if len(result) > 0 {
|
||||||
for _, v := range result {
|
// for _, v := range result {
|
||||||
v = utils.AddOssDomain(v)
|
// v = utils.AddOssDomain(v)
|
||||||
questionImage = append(questionImage, v)
|
// questionImage = append(questionImage, v)
|
||||||
}
|
// }
|
||||||
}
|
// }
|
||||||
}
|
// }
|
||||||
|
//
|
||||||
return &ShareQuestionDto{
|
// return &ShareQuestionDto{
|
||||||
QuestionName: m.QuestionName,
|
// QuestionName: m.QuestionName,
|
||||||
QuestionType: m.QuestionType,
|
// QuestionType: m.QuestionType,
|
||||||
QuestionSource: m.QuestionSource,
|
// QuestionSource: m.QuestionSource,
|
||||||
QuestionImage: questionImage,
|
// QuestionImage: questionImage,
|
||||||
QuestionAnswer: m.QuestionAnswer,
|
// QuestionAnswer: m.QuestionAnswer,
|
||||||
QuestionAnalysis: m.QuestionAnalysis,
|
// QuestionAnalysis: m.QuestionAnalysis,
|
||||||
Difficulty: m.Difficulty,
|
// Difficulty: m.Difficulty,
|
||||||
}
|
// }
|
||||||
}
|
//}
|
||||||
|
|
||||||
// LoadQuestionQa 加载题库数据
|
// LoadQuestionQa 加载题库数据
|
||||||
func (r *ShareDto) LoadQuestionQa(m *model.QuestionQa) *ShareDto {
|
func (r *ShareDto) LoadQuestionQa(m *model.QuestionQa) *ShareDto {
|
||||||
@ -54,3 +53,19 @@ func (r *ShareDto) LoadQuestionQa(m *model.QuestionQa) *ShareDto {
|
|||||||
}
|
}
|
||||||
return r
|
return r
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// LoadQuestion 加载题库关联题目列表
|
||||||
|
func (r *ShareDto) LoadQuestion(m []*model.Question) *ShareDto {
|
||||||
|
if len(m) > 0 {
|
||||||
|
r.Question = GetQuestionListDto(m)
|
||||||
|
}
|
||||||
|
return r
|
||||||
|
}
|
||||||
|
|
||||||
|
// LoadBaseTokenItem 加载题库关联飞花令-列表
|
||||||
|
func (r *ShareDto) LoadBaseTokenItem(m []*model.BaseTokenItem) *ShareDto {
|
||||||
|
if len(m) > 0 {
|
||||||
|
r.BaseTokenItem = GetBaseTokenItemListDto(m)
|
||||||
|
}
|
||||||
|
return r
|
||||||
|
}
|
||||||
|
|||||||
@ -12,6 +12,7 @@ type QuestionQaToken struct {
|
|||||||
TokenId int64 `gorm:"column:token_id;type:bigint(19);comment:飞花令id" json:"token_id"`
|
TokenId int64 `gorm:"column:token_id;type:bigint(19);comment:飞花令id" json:"token_id"`
|
||||||
Sort int `gorm:"column:sort;type:tinyint(1);comment:排序(越大越靠前)" json:"sort"`
|
Sort int `gorm:"column:sort;type:tinyint(1);comment:排序(越大越靠前)" json:"sort"`
|
||||||
Model
|
Model
|
||||||
|
BaseTokenItem []*BaseTokenItem `gorm:"foreignKey:TokenId;references:token_id" json:"base_token_item"`
|
||||||
}
|
}
|
||||||
|
|
||||||
func (m *QuestionQaToken) TableName() string {
|
func (m *QuestionQaToken) TableName() string {
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user